puppet 6.16.0-x64-mingw32 → 6.20.0-x64-mingw32
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 -16
- data/Gemfile +6 -2
- data/Gemfile.lock +40 -36
- data/README.md +3 -4
- data/Rakefile +4 -12
- data/lib/puppet/agent.rb +2 -2
- data/lib/puppet/agent/locker.rb +0 -7
- data/lib/puppet/application.rb +10 -6
- data/lib/puppet/application/agent.rb +23 -6
- data/lib/puppet/application/apply.rb +20 -21
- data/lib/puppet/application/device.rb +1 -0
- data/lib/puppet/application/doc.rb +1 -1
- data/lib/puppet/application/filebucket.rb +2 -2
- data/lib/puppet/application/lookup.rb +16 -4
- data/lib/puppet/application/script.rb +1 -0
- data/lib/puppet/application_support.rb +7 -0
- data/lib/puppet/configurer.rb +70 -20
- data/lib/puppet/configurer/downloader.rb +31 -10
- data/lib/puppet/confine.rb +2 -2
- data/lib/puppet/confine/any.rb +1 -1
- data/lib/puppet/defaults.rb +113 -46
- data/lib/puppet/environments.rb +84 -59
- data/lib/puppet/face/catalog.rb +1 -1
- data/lib/puppet/face/config.rb +56 -16
- data/lib/puppet/face/epp.rb +12 -2
- data/lib/puppet/face/facts.rb +60 -0
- data/lib/puppet/face/node.rb +3 -3
- data/lib/puppet/face/node/clean.rb +2 -2
- data/lib/puppet/face/status.rb +1 -1
- data/lib/puppet/feature/base.rb +1 -1
- data/lib/puppet/ffi/posix.rb +10 -0
- data/lib/puppet/ffi/posix/constants.rb +14 -0
- data/lib/puppet/ffi/posix/functions.rb +24 -0
- data/lib/puppet/file_bucket/dipper.rb +1 -1
- data/lib/puppet/file_serving/http_metadata.rb +13 -1
- data/lib/puppet/file_serving/metadata.rb +4 -1
- data/lib/puppet/file_serving/mount/locales.rb +1 -2
- data/lib/puppet/file_serving/mount/pluginfacts.rb +1 -2
- data/lib/puppet/file_serving/mount/plugins.rb +1 -2
- data/lib/puppet/file_serving/terminus_selector.rb +7 -8
- data/lib/puppet/file_system/file_impl.rb +4 -4
- data/lib/puppet/file_system/uniquefile.rb +8 -16
- data/lib/puppet/forge.rb +1 -1
- data/lib/puppet/forge/cache.rb +1 -1
- data/lib/puppet/forge/repository.rb +3 -7
- data/lib/puppet/functions/epp.rb +1 -0
- data/lib/puppet/functions/inline_epp.rb +1 -0
- data/lib/puppet/functions/lstrip.rb +4 -4
- data/lib/puppet/functions/new.rb +8 -3
- data/lib/puppet/functions/reverse_each.rb +1 -1
- data/lib/puppet/functions/rstrip.rb +4 -4
- data/lib/puppet/functions/step.rb +1 -1
- data/lib/puppet/functions/strip.rb +4 -4
- data/lib/puppet/gettext/config.rb +5 -5
- data/lib/puppet/gettext/module_translations.rb +4 -4
- data/lib/puppet/http.rb +1 -0
- data/lib/puppet/http/client.rb +6 -1
- data/lib/puppet/http/redirector.rb +9 -7
- data/lib/puppet/http/resolver.rb +5 -8
- data/lib/puppet/http/resolver/server_list.rb +18 -36
- data/lib/puppet/http/resolver/settings.rb +4 -4
- data/lib/puppet/http/resolver/srv.rb +5 -5
- data/lib/puppet/http/response.rb +19 -0
- data/lib/puppet/http/service.rb +3 -1
- data/lib/puppet/http/service/compiler.rb +1 -1
- data/lib/puppet/http/service/file_server.rb +1 -1
- data/lib/puppet/http/service/puppetserver.rb +39 -0
- data/lib/puppet/http/session.rb +5 -4
- data/lib/puppet/indirector.rb +1 -1
- data/lib/puppet/indirector/catalog/compiler.rb +1 -1
- data/lib/puppet/indirector/exec.rb +1 -1
- data/lib/puppet/indirector/fact_search.rb +60 -0
- data/lib/puppet/indirector/facts/facter.rb +3 -3
- data/lib/puppet/indirector/facts/json.rb +27 -0
- data/lib/puppet/indirector/facts/yaml.rb +4 -59
- data/lib/puppet/indirector/file_content/rest.rb +1 -1
- data/lib/puppet/indirector/file_metadata/http.rb +25 -5
- data/lib/puppet/indirector/file_metadata/rest.rb +2 -2
- data/lib/puppet/indirector/hiera.rb +4 -0
- data/lib/puppet/indirector/indirection.rb +1 -1
- data/lib/puppet/indirector/json.rb +5 -1
- data/lib/puppet/indirector/msgpack.rb +1 -1
- data/lib/puppet/indirector/node/json.rb +8 -0
- data/lib/puppet/indirector/report/json.rb +34 -0
- data/lib/puppet/indirector/report/processor.rb +2 -2
- data/lib/puppet/indirector/request.rb +5 -5
- data/lib/puppet/indirector/yaml.rb +1 -1
- data/lib/puppet/module.rb +1 -2
- data/lib/puppet/module_tool/applications/installer.rb +48 -2
- data/lib/puppet/module_tool/errors/shared.rb +17 -2
- data/lib/puppet/network/format_support.rb +2 -2
- data/lib/puppet/network/formats.rb +2 -1
- 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/api/master/v3/environments.rb +0 -1
- data/lib/puppet/network/http/connection_adapter.rb +6 -4
- data/lib/puppet/network/http/route.rb +2 -2
- data/lib/puppet/node/environment.rb +12 -5
- data/lib/puppet/node/facts.rb +17 -0
- data/lib/puppet/pal/pal_impl.rb +90 -13
- data/lib/puppet/parameter.rb +1 -1
- data/lib/puppet/parser/ast/leaf.rb +7 -6
- data/lib/puppet/parser/ast/pops_bridge.rb +0 -4
- data/lib/puppet/parser/compiler.rb +1 -1
- 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 +21 -17
- data/lib/puppet/parser/functions/create_resources.rb +11 -7
- data/lib/puppet/parser/resource.rb +3 -2
- data/lib/puppet/parser/resource/param.rb +6 -0
- data/lib/puppet/parser/templatewrapper.rb +1 -1
- data/lib/puppet/parser/type_loader.rb +2 -2
- data/lib/puppet/pops/adaptable.rb +7 -13
- data/lib/puppet/pops/adapters.rb +8 -4
- data/lib/puppet/pops/evaluator/collectors/abstract_collector.rb +1 -3
- data/lib/puppet/pops/evaluator/deferred_resolver.rb +5 -3
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +27 -8
- data/lib/puppet/pops/evaluator/runtime3_converter.rb +2 -2
- data/lib/puppet/pops/issues.rb +5 -0
- data/lib/puppet/pops/loader/runtime3_type_loader.rb +4 -2
- data/lib/puppet/pops/loaders.rb +18 -11
- data/lib/puppet/pops/lookup/context.rb +1 -1
- data/lib/puppet/pops/lookup/hiera_config.rb +14 -1
- data/lib/puppet/pops/model/ast_transformer.rb +1 -1
- data/lib/puppet/pops/resource/resource_type_impl.rb +2 -0
- data/lib/puppet/pops/types/iterable.rb +34 -8
- data/lib/puppet/pops/types/p_meta_type.rb +1 -1
- data/lib/puppet/pops/types/p_type_set_type.rb +4 -0
- data/lib/puppet/pops/validation/checker4_0.rb +29 -15
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +1 -0
- data/lib/puppet/provider/file/windows.rb +1 -1
- data/lib/puppet/provider/package/apt.rb +38 -0
- data/lib/puppet/provider/package/aptitude.rb +1 -1
- data/lib/puppet/provider/package/dpkg.rb +1 -1
- data/lib/puppet/provider/package/gem.rb +4 -2
- data/lib/puppet/provider/package/pip2.rb +17 -0
- data/lib/puppet/provider/package/puppet_gem.rb +5 -0
- data/lib/puppet/provider/package/puppetserver_gem.rb +180 -0
- data/lib/puppet/provider/package/yum.rb +2 -1
- data/lib/puppet/provider/package/zypper.rb +3 -0
- data/lib/puppet/provider/service/windows.rb +23 -7
- data/lib/puppet/provider/user/aix.rb +3 -3
- data/lib/puppet/provider/user/user_role_add.rb +1 -1
- data/lib/puppet/provider/user/useradd.rb +11 -4
- data/lib/puppet/provider/user/windows_adsi.rb +18 -1
- data/lib/puppet/reference/configuration.rb +6 -5
- data/lib/puppet/reports/http.rb +2 -0
- data/lib/puppet/resource.rb +2 -1
- data/lib/puppet/resource/type.rb +10 -1
- data/lib/puppet/rest/route.rb +2 -2
- data/lib/puppet/settings.rb +63 -21
- data/lib/puppet/settings/alias_setting.rb +37 -0
- data/lib/puppet/settings/base_setting.rb +26 -2
- data/lib/puppet/ssl/ssl_context.rb +2 -2
- data/lib/puppet/ssl/ssl_provider.rb +20 -1
- data/lib/puppet/ssl/validator/default_validator.rb +1 -1
- data/lib/puppet/test/test_helper.rb +18 -13
- data/lib/puppet/transaction.rb +2 -2
- data/lib/puppet/transaction/persistence.rb +1 -1
- data/lib/puppet/transaction/report.rb +12 -8
- data/lib/puppet/trusted_external.rb +29 -1
- data/lib/puppet/type.rb +15 -7
- data/lib/puppet/type/file.rb +40 -15
- data/lib/puppet/type/file/checksum.rb +4 -4
- data/lib/puppet/type/file/source.rb +32 -12
- data/lib/puppet/type/filebucket.rb +1 -1
- data/lib/puppet/type/notify.rb +2 -2
- data/lib/puppet/type/service.rb +53 -0
- data/lib/puppet/type/user.rb +18 -3
- data/lib/puppet/util.rb +41 -3
- data/lib/puppet/util/autoload.rb +10 -15
- data/lib/puppet/util/character_encoding.rb +9 -5
- data/lib/puppet/util/checksums.rb +19 -4
- data/lib/puppet/util/connection.rb +8 -8
- data/lib/puppet/util/execution.rb +2 -2
- data/lib/puppet/util/fact_dif.rb +62 -0
- data/lib/puppet/util/fileparsing.rb +2 -2
- data/lib/puppet/util/posix.rb +54 -5
- data/lib/puppet/util/provider_features.rb +1 -1
- data/lib/puppet/util/reference.rb +1 -1
- data/lib/puppet/util/rubygems.rb +5 -1
- data/lib/puppet/util/run_mode.rb +5 -1
- data/lib/puppet/util/windows.rb +1 -0
- data/lib/puppet/util/windows/api_types.rb +60 -33
- data/lib/puppet/util/windows/eventlog.rb +1 -6
- data/lib/puppet/util/windows/monkey_patches/dir.rb +40 -0
- data/lib/puppet/util/windows/principal.rb +8 -6
- data/lib/puppet/util/windows/registry.rb +11 -11
- data/lib/puppet/util/windows/security.rb +4 -4
- data/lib/puppet/util/windows/service.rb +43 -26
- data/lib/puppet/util/windows/user.rb +242 -8
- data/lib/puppet/version.rb +1 -1
- data/locales/puppet.pot +501 -443
- data/man/man5/puppet.conf.5 +70 -24
- data/man/man8/puppet-agent.8 +8 -5
- data/man/man8/puppet-apply.8 +2 -2
- data/man/man8/puppet-catalog.8 +1 -1
- data/man/man8/puppet-config.8 +6 -6
- 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 +32 -1
- data/man/man8/puppet-filebucket.8 +3 -3
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-key.8 +1 -1
- data/man/man8/puppet-lookup.8 +2 -2
- data/man/man8/puppet-man.8 +1 -1
- data/man/man8/puppet-module.8 +1 -1
- data/man/man8/puppet-node.8 +7 -4
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +4 -1
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +2 -2
- data/man/man8/puppet-ssl.8 +1 -1
- data/man/man8/puppet-status.8 +2 -2
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/integration/application/agent/cached_deferred_catalog.json +91 -0
- data/spec/fixtures/integration/application/apply/environments/spec/modules/amod/lib/puppet/provider/applytest/applytest.rb +2 -0
- data/spec/fixtures/integration/application/apply/environments/spec/modules/amod/lib/puppet/type/applytest.rb +25 -0
- data/spec/fixtures/unit/forge/bacula-releases.json +128 -0
- data/spec/fixtures/unit/forge/bacula.tar.gz +0 -0
- data/spec/fixtures/unit/provider/package/puppetserver_gem/gem-list-local-packages +30 -0
- data/spec/fixtures/unit/provider/user/aix/aix_passwd_file.out +4 -0
- data/spec/integration/application/agent_spec.rb +263 -54
- data/spec/integration/application/apply_spec.rb +168 -149
- data/spec/integration/application/doc_spec.rb +16 -6
- data/spec/integration/application/filebucket_spec.rb +70 -21
- data/spec/integration/application/help_spec.rb +42 -0
- data/spec/integration/application/lookup_spec.rb +13 -0
- data/spec/integration/application/module_spec.rb +68 -0
- data/spec/integration/application/plugin_spec.rb +53 -3
- data/spec/integration/configurer_spec.rb +14 -0
- data/spec/integration/data_binding_spec.rb +82 -0
- data/spec/integration/defaults_spec.rb +20 -3
- data/spec/integration/directory_environments_spec.rb +17 -17
- data/spec/integration/environments/setting_hooks_spec.rb +1 -1
- data/spec/integration/indirector/facts/facter_spec.rb +8 -6
- data/spec/integration/network/http_pool_spec.rb +26 -9
- data/spec/integration/node/environment_spec.rb +1 -1
- data/spec/integration/parser/compiler_spec.rb +11 -0
- data/spec/integration/resource/type_collection_spec.rb +2 -6
- data/spec/integration/transaction_spec.rb +4 -9
- data/spec/integration/type/file_spec.rb +1 -1
- data/spec/integration/util/execution_spec.rb +22 -0
- data/spec/integration/util/windows/adsi_spec.rb +5 -3
- data/spec/integration/util/windows/monkey_patches/dir_spec.rb +11 -0
- data/spec/integration/util/windows/process_spec.rb +26 -32
- data/spec/integration/util/windows/registry_spec.rb +7 -17
- data/spec/integration/util/windows/user_spec.rb +47 -5
- data/spec/integration/util_spec.rb +7 -33
- data/spec/lib/puppet_spec/matchers.rb +0 -80
- data/spec/lib/puppet_spec/puppetserver.rb +8 -0
- data/spec/lib/puppet_spec/settings.rb +6 -1
- data/spec/shared_contexts/types_setup.rb +2 -0
- data/spec/spec_helper.rb +1 -4
- data/spec/unit/agent_spec.rb +8 -6
- data/spec/unit/application/agent_spec.rb +3 -5
- data/spec/unit/application/config_spec.rb +224 -4
- data/spec/unit/application/doc_spec.rb +2 -2
- data/spec/unit/application/face_base_spec.rb +6 -4
- data/spec/unit/application/facts_spec.rb +41 -10
- data/spec/unit/application/filebucket_spec.rb +0 -2
- data/spec/unit/application/man_spec.rb +52 -0
- data/spec/unit/application/resource_spec.rb +3 -1
- data/spec/unit/application/ssl_spec.rb +15 -2
- data/spec/unit/application_spec.rb +60 -13
- data/spec/unit/configurer/downloader_spec.rb +10 -0
- data/spec/unit/configurer/fact_handler_spec.rb +4 -4
- data/spec/unit/configurer_spec.rb +86 -37
- data/spec/unit/confine/feature_spec.rb +1 -1
- data/spec/unit/confine_spec.rb +10 -3
- data/spec/unit/context/trusted_information_spec.rb +10 -4
- data/spec/unit/defaults_spec.rb +20 -1
- data/spec/unit/environments_spec.rb +176 -32
- data/spec/unit/face/config_spec.rb +65 -12
- data/spec/unit/face/node_spec.rb +2 -13
- data/spec/unit/file_serving/configuration/parser_spec.rb +0 -1
- data/spec/unit/file_serving/http_metadata_spec.rb +37 -14
- data/spec/unit/file_serving/metadata_spec.rb +3 -3
- data/spec/unit/file_serving/mount/locales_spec.rb +2 -2
- data/spec/unit/file_serving/mount/pluginfacts_spec.rb +2 -2
- data/spec/unit/file_serving/mount/plugins_spec.rb +2 -2
- data/spec/unit/file_serving/terminus_helper_spec.rb +11 -4
- data/spec/unit/file_serving/terminus_selector_spec.rb +45 -26
- data/spec/unit/file_system/uniquefile_spec.rb +18 -0
- data/spec/unit/file_system_spec.rb +1 -2
- data/spec/unit/forge/module_release_spec.rb +2 -7
- data/spec/unit/functions/inline_epp_spec.rb +26 -1
- data/spec/unit/http/client_spec.rb +64 -9
- data/spec/unit/http/resolver_spec.rb +24 -5
- data/spec/unit/http/response_spec.rb +6 -0
- data/spec/unit/http/service/ca_spec.rb +2 -3
- data/spec/unit/http/service/compiler_spec.rb +51 -3
- data/spec/unit/http/service/file_server_spec.rb +2 -3
- data/spec/unit/http/service/puppetserver_spec.rb +82 -0
- data/spec/unit/http/service/report_spec.rb +2 -3
- data/spec/unit/http/service_spec.rb +1 -2
- data/spec/unit/http/session_spec.rb +8 -21
- data/spec/unit/indirector/catalog/json_spec.rb +1 -1
- data/spec/unit/indirector/catalog/rest_spec.rb +1 -1
- data/spec/unit/indirector/face_spec.rb +0 -1
- data/spec/unit/indirector/facts/facter_spec.rb +0 -1
- data/spec/unit/indirector/facts/json_spec.rb +255 -0
- data/spec/unit/indirector/facts/rest_spec.rb +1 -1
- data/spec/unit/indirector/file_bucket_file/selector_spec.rb +26 -8
- data/spec/unit/indirector/file_metadata/http_spec.rb +27 -0
- data/spec/unit/indirector/indirection_spec.rb +8 -12
- data/spec/unit/indirector/json_spec.rb +8 -8
- data/spec/unit/indirector/key/file_spec.rb +0 -1
- data/spec/unit/indirector/msgpack_spec.rb +8 -8
- data/spec/unit/indirector/node/json_spec.rb +33 -0
- data/spec/unit/indirector/node/rest_spec.rb +1 -1
- data/spec/{integration/indirector/report/yaml.rb → unit/indirector/report/json_spec.rb} +13 -24
- data/spec/unit/indirector/report/yaml_spec.rb +72 -8
- data/spec/unit/indirector/request_spec.rb +5 -5
- data/spec/unit/indirector/rest_spec.rb +1 -1
- data/spec/unit/indirector/status/rest_spec.rb +1 -1
- data/spec/unit/indirector/yaml_spec.rb +7 -7
- data/spec/unit/indirector_spec.rb +2 -2
- data/spec/unit/interface_spec.rb +3 -3
- data/spec/unit/module_tool/applications/installer_spec.rb +66 -0
- data/spec/unit/module_tool/tar/mini_spec.rb +20 -0
- data/spec/unit/network/authconfig_spec.rb +0 -3
- data/spec/unit/network/format_support_spec.rb +3 -2
- data/spec/unit/network/http/api/indirected_routes_spec.rb +2 -10
- data/spec/unit/network/http/api/master/v3/environments_spec.rb +12 -23
- data/spec/unit/network/http/connection_spec.rb +42 -32
- data/spec/unit/network/http/handler_spec.rb +0 -5
- data/spec/unit/node/environment_spec.rb +18 -1
- data/spec/unit/parser/ast/block_expression_spec.rb +1 -1
- data/spec/unit/parser/compiler_spec.rb +3 -19
- data/spec/unit/parser/environment_compiler_spec.rb +7 -0
- data/spec/unit/parser/resource_spec.rb +14 -8
- data/spec/unit/parser/scope_spec.rb +1 -1
- data/spec/unit/parser/templatewrapper_spec.rb +4 -3
- data/spec/unit/pops/evaluator/deferred_resolver_spec.rb +20 -0
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +15 -1
- data/spec/unit/pops/loaders/loaders_spec.rb +71 -1
- data/spec/unit/pops/lookup/lookup_spec.rb +25 -0
- data/spec/unit/pops/types/type_calculator_spec.rb +1 -11
- data/spec/unit/property_spec.rb +1 -0
- data/spec/unit/provider/exec_spec.rb +4 -3
- data/spec/unit/provider/nameservice_spec.rb +66 -65
- data/spec/unit/provider/package/apt_spec.rb +76 -3
- data/spec/unit/provider/package/aptitude_spec.rb +1 -0
- data/spec/unit/provider/package/base_spec.rb +6 -5
- data/spec/unit/provider/package/dpkg_spec.rb +22 -7
- data/spec/unit/provider/package/openbsd_spec.rb +2 -0
- data/spec/unit/provider/package/pacman_spec.rb +18 -12
- data/spec/unit/provider/package/pip2_spec.rb +36 -0
- data/spec/unit/provider/package/pip_spec.rb +6 -11
- data/spec/unit/provider/package/pkgdmg_spec.rb +0 -4
- data/spec/unit/provider/package/puppet_gem_spec.rb +4 -1
- data/spec/unit/provider/package/puppetserver_gem_spec.rb +137 -0
- data/spec/unit/provider/package/yum_spec.rb +31 -0
- data/spec/unit/provider/package/zypper_spec.rb +14 -0
- data/spec/unit/provider/service/base_spec.rb +2 -4
- data/spec/unit/provider/service/bsd_spec.rb +5 -1
- data/spec/unit/provider/service/daemontools_spec.rb +1 -1
- data/spec/unit/provider/service/debian_spec.rb +3 -5
- data/spec/unit/provider/service/freebsd_spec.rb +1 -1
- data/spec/unit/provider/service/gentoo_spec.rb +4 -5
- data/spec/unit/provider/service/init_spec.rb +45 -5
- data/spec/unit/provider/service/launchd_spec.rb +5 -6
- data/spec/unit/provider/service/openrc_spec.rb +4 -5
- data/spec/unit/provider/service/openwrt_spec.rb +1 -1
- data/spec/unit/provider/service/redhat_spec.rb +1 -1
- data/spec/unit/provider/service/runit_spec.rb +2 -1
- data/spec/unit/provider/service/smf_spec.rb +1 -1
- data/spec/unit/provider/service/src_spec.rb +3 -5
- data/spec/unit/provider/service/systemd_spec.rb +3 -6
- data/spec/unit/provider/service/upstart_spec.rb +4 -5
- data/spec/unit/provider/service/windows_spec.rb +50 -14
- data/spec/unit/provider/user/aix_spec.rb +5 -0
- data/spec/unit/provider/user/hpux_spec.rb +1 -1
- data/spec/unit/provider/user/openbsd_spec.rb +1 -0
- data/spec/unit/provider/user/pw_spec.rb +2 -0
- data/spec/unit/provider/user/useradd_spec.rb +23 -16
- data/spec/unit/provider/user/windows_adsi_spec.rb +82 -0
- data/spec/unit/provider_spec.rb +8 -10
- data/spec/unit/puppet_pal_2pec.rb +40 -0
- data/spec/unit/puppet_pal_catalog_spec.rb +45 -0
- data/spec/unit/reports/store_spec.rb +17 -13
- data/spec/unit/resource/capability_finder_spec.rb +6 -1
- data/spec/unit/resource/type_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +14 -13
- data/spec/unit/rest/route_spec.rb +4 -4
- data/spec/unit/settings_spec.rb +576 -239
- data/spec/unit/ssl/base_spec.rb +0 -1
- data/spec/unit/ssl/host_spec.rb +0 -5
- data/spec/unit/ssl/ssl_provider_spec.rb +82 -50
- data/spec/unit/test/test_helper_spec.rb +17 -0
- data/spec/unit/transaction/additional_resource_generator_spec.rb +3 -7
- data/spec/unit/transaction/event_manager_spec.rb +14 -11
- data/spec/unit/transaction/persistence_spec.rb +15 -0
- data/spec/unit/transaction/report_spec.rb +3 -1
- data/spec/unit/transaction_spec.rb +13 -4
- data/spec/unit/type/file/content_spec.rb +0 -1
- data/spec/unit/type/file/selinux_spec.rb +0 -2
- data/spec/unit/type/file/source_spec.rb +4 -4
- data/spec/unit/type/file_spec.rb +122 -102
- data/spec/unit/type/filebucket_spec.rb +1 -1
- data/spec/unit/type/group_spec.rb +13 -6
- data/spec/unit/type/resources_spec.rb +7 -7
- data/spec/unit/type/service_spec.rb +210 -1
- data/spec/unit/type/tidy_spec.rb +0 -1
- data/spec/unit/type/user_spec.rb +31 -2
- data/spec/unit/type_spec.rb +52 -2
- data/spec/unit/util/at_fork_spec.rb +2 -2
- data/spec/unit/util/autoload_spec.rb +5 -1
- data/spec/unit/util/backups_spec.rb +1 -2
- data/spec/unit/util/character_encoding_spec.rb +4 -4
- data/spec/unit/util/checksums_spec.rb +16 -0
- data/spec/unit/util/command_line_spec.rb +11 -6
- data/spec/unit/util/execution_spec.rb +15 -11
- data/spec/unit/util/inifile_spec.rb +6 -14
- data/spec/unit/util/log_spec.rb +8 -7
- data/spec/unit/util/logging_spec.rb +3 -3
- data/spec/unit/util/posix_spec.rb +363 -15
- data/spec/unit/util/rubygems_spec.rb +2 -2
- data/spec/unit/util/run_mode_spec.rb +6 -6
- data/spec/unit/util/selinux_spec.rb +76 -52
- data/spec/unit/util/storage_spec.rb +3 -1
- data/spec/unit/util/suidmanager_spec.rb +44 -41
- 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_spec.rb +16 -9
- data/spec/unit/x509/cert_provider_spec.rb +1 -1
- metadata +52 -53
- data/spec/integration/faces/config_spec.rb +0 -91
- data/spec/integration/faces/documentation_spec.rb +0 -57
- data/spec/integration/file_bucket/file_spec.rb +0 -50
- data/spec/integration/file_serving/content_spec.rb +0 -7
- data/spec/integration/file_serving/fileset_spec.rb +0 -12
- data/spec/integration/file_serving/metadata_spec.rb +0 -8
- data/spec/integration/file_serving/terminus_helper_spec.rb +0 -20
- data/spec/integration/file_system/uniquefile_spec.rb +0 -26
- data/spec/integration/module_tool/forge_spec.rb +0 -51
- data/spec/integration/module_tool/tar/mini_spec.rb +0 -28
- data/spec/integration/provider/service/init_spec.rb +0 -48
- data/spec/integration/provider/service/systemd_spec.rb +0 -25
- data/spec/integration/provider/service/windows_spec.rb +0 -50
- data/spec/integration/reference/providers_spec.rb +0 -21
- data/spec/integration/reports_spec.rb +0 -13
- data/spec/integration/ssl/certificate_request_spec.rb +0 -44
- data/spec/integration/ssl/host_spec.rb +0 -72
- data/spec/integration/ssl/key_spec.rb +0 -99
- data/spec/integration/test/test_helper_spec.rb +0 -31
- data/spec/shared_behaviours/file_serving_model.rb +0 -51
- data/spec/unit/face/catalog_spec.rb +0 -6
- data/spec/unit/face/man_spec.rb +0 -25
- data/spec/unit/face/module_spec.rb +0 -3
- data/spec/unit/man_spec.rb +0 -31
| @@ -8,7 +8,7 @@ module Puppet::Util | |
| 8 8 | 
             
                # The logic for server and port is kind of gross. In summary:
         | 
| 9 9 | 
             
                # IF an endpoint-specific setting is requested AND that setting has been set by the user
         | 
| 10 10 | 
             
                #    Use that setting.
         | 
| 11 | 
            -
                #         The defaults for these settings are the "normal" server/ | 
| 11 | 
            +
                #         The defaults for these settings are the "normal" server/serverport settings, so
         | 
| 12 12 | 
             
                #         when they are unset we instead want to "fall back" to the failover-selected
         | 
| 13 13 | 
             
                #         host/port pair.
         | 
| 14 14 | 
             
                # ELSE IF we have a failover-selected host/port
         | 
| @@ -17,7 +17,7 @@ module Puppet::Util | |
| 17 17 | 
             
                #    Use the first entry - failover hasn't happened yet, but that
         | 
| 18 18 | 
             
                #    setting is still authoritative
         | 
| 19 19 | 
             
                # ELSE
         | 
| 20 | 
            -
                #    Go for the legacy server/ | 
| 20 | 
            +
                #    Go for the legacy server/serverport settings, and hope for the best
         | 
| 21 21 |  | 
| 22 22 | 
             
                # Determines which server to use based on the specified setting, taking into
         | 
| 23 23 | 
             
                # account HA fallback from server_list.
         | 
| @@ -55,7 +55,7 @@ module Puppet::Util | |
| 55 55 | 
             
                # @param [Symbol] server_setting The server setting assoicated with this route.
         | 
| 56 56 | 
             
                # @return [Integer] the port to use for use in the request
         | 
| 57 57 | 
             
                def self.determine_port(port_setting, server_setting)
         | 
| 58 | 
            -
                  if (port_setting && port_setting != : | 
| 58 | 
            +
                  if (port_setting && port_setting != :serverport && Puppet.settings.set_by_config?(port_setting)) ||
         | 
| 59 59 | 
             
                     (server_setting && server_setting != :server && Puppet.settings.set_by_config?(server_setting))
         | 
| 60 60 | 
             
                    debug_once _("Selected port from the %{setting} setting: %{port}") % {setting: port_setting, port: Puppet.settings[port_setting].to_i}
         | 
| 61 61 | 
             
                    Puppet.settings[port_setting].to_i
         | 
| @@ -65,18 +65,18 @@ module Puppet::Util | |
| 65 65 | 
             
                      if primary_server
         | 
| 66 66 | 
             
                        # Port might not be set, so we want to fallback in that
         | 
| 67 67 | 
             
                        # case. We know we don't need to use `setting` here, since
         | 
| 68 | 
            -
                        # the default value of every port setting is ` | 
| 68 | 
            +
                        # the default value of every port setting is `serverport`
         | 
| 69 69 | 
             
                        if primary_server[1]
         | 
| 70 70 | 
             
                          #TRANSLATORS 'server_list' is the name of a setting and should not be translated
         | 
| 71 71 | 
             
                          debug_once _("Dynamically-bound port lookup failed; using first entry from the `server_list` setting: %{port}") % {port: primary_server[1]}
         | 
| 72 72 | 
             
                          primary_server[1]
         | 
| 73 73 | 
             
                        else
         | 
| 74 | 
            -
                          #TRANSLATORS ' | 
| 75 | 
            -
                          debug_once _("Dynamically-bound port lookup failed; falling back to ` | 
| 76 | 
            -
                          Puppet.settings[: | 
| 74 | 
            +
                          #TRANSLATORS 'serverport' is the name of a setting and should not be translated
         | 
| 75 | 
            +
                          debug_once _("Dynamically-bound port lookup failed; falling back to `serverport` setting: %{port}") % {port: Puppet.settings[:serverport]}
         | 
| 76 | 
            +
                          Puppet.settings[:serverport]
         | 
| 77 77 | 
             
                        end
         | 
| 78 78 | 
             
                      else
         | 
| 79 | 
            -
                        port_setting ||= : | 
| 79 | 
            +
                        port_setting ||= :serverport
         | 
| 80 80 | 
             
                        debug_once _("Dynamically-bound port lookup failed; falling back to %{setting} setting: %{port}") % {setting: port_setting, port: Puppet.settings[port_setting]}
         | 
| 81 81 | 
             
                        Puppet.settings[port_setting]
         | 
| 82 82 | 
             
                      end
         | 
| @@ -68,7 +68,7 @@ module Puppet::Util::Execution | |
| 68 68 | 
             
                if respond_to? :debug
         | 
| 69 69 | 
             
                  debug "Executing '#{command_str}'"
         | 
| 70 70 | 
             
                else
         | 
| 71 | 
            -
                  Puppet.debug "Executing '#{command_str}'"
         | 
| 71 | 
            +
                  Puppet.debug { "Executing '#{command_str}'" }
         | 
| 72 72 | 
             
                end
         | 
| 73 73 |  | 
| 74 74 | 
             
                # force the run of the command with
         | 
| @@ -186,7 +186,7 @@ module Puppet::Util::Execution | |
| 186 186 | 
             
                if respond_to? :debug
         | 
| 187 187 | 
             
                  debug "Executing#{user_log_s}: '#{command_str}'"
         | 
| 188 188 | 
             
                else
         | 
| 189 | 
            -
                  Puppet.debug "Executing#{user_log_s}: '#{command_str}'"
         | 
| 189 | 
            +
                  Puppet.debug { "Executing#{user_log_s}: '#{command_str}'" }
         | 
| 190 190 | 
             
                end
         | 
| 191 191 |  | 
| 192 192 | 
             
                null_file = Puppet::Util::Platform.windows? ? 'NUL' : '/dev/null'
         | 
| @@ -0,0 +1,62 @@ | |
| 1 | 
            +
            require 'json'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            class FactDif
         | 
| 4 | 
            +
              def initialize(old_output, new_output, exclude_list = [])
         | 
| 5 | 
            +
                @c_facter = JSON.parse(old_output)['values']
         | 
| 6 | 
            +
                @next_facter = JSON.parse(new_output)['values']
         | 
| 7 | 
            +
                @exclude_list = exclude_list
         | 
| 8 | 
            +
                @diff = {}
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
              def difs
         | 
| 12 | 
            +
                search_hash(@c_facter, [])
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                @diff
         | 
| 15 | 
            +
              end
         | 
| 16 | 
            +
             | 
| 17 | 
            +
              private
         | 
| 18 | 
            +
             | 
| 19 | 
            +
              def search_hash(sh, path = [])
         | 
| 20 | 
            +
                if sh.is_a?(Hash)
         | 
| 21 | 
            +
                  sh.each do |k, v|
         | 
| 22 | 
            +
                    search_hash(v, path.push(k))
         | 
| 23 | 
            +
                    path.pop
         | 
| 24 | 
            +
                  end
         | 
| 25 | 
            +
                elsif sh.is_a?(Array)
         | 
| 26 | 
            +
                  sh.each_with_index do |v, index|
         | 
| 27 | 
            +
                    search_hash(v, path.push(index))
         | 
| 28 | 
            +
                    path.pop
         | 
| 29 | 
            +
                  end
         | 
| 30 | 
            +
                else
         | 
| 31 | 
            +
                  compare(path, sh)
         | 
| 32 | 
            +
                end
         | 
| 33 | 
            +
              end
         | 
| 34 | 
            +
             | 
| 35 | 
            +
              def compare(fact_path, old_value)
         | 
| 36 | 
            +
                new_value = @next_facter.dig(*fact_path)
         | 
| 37 | 
            +
                if different?(new_value, old_value) && !excluded?(fact_path.join('.'))
         | 
| 38 | 
            +
                  @diff[fact_path.join('.')] = { new_value: new_value, old_value: old_value }
         | 
| 39 | 
            +
                end
         | 
| 40 | 
            +
              end
         | 
| 41 | 
            +
             | 
| 42 | 
            +
              def different?(new, old)
         | 
| 43 | 
            +
                if old.is_a?(String) && new.is_a?(String)
         | 
| 44 | 
            +
                  old_values = old.split(',')
         | 
| 45 | 
            +
                  new_values = new.split(',')
         | 
| 46 | 
            +
             | 
| 47 | 
            +
                  diff = old_values - new_values
         | 
| 48 | 
            +
                  # also add new entries only available in Facter 4
         | 
| 49 | 
            +
                  diff.concat(new_values - old_values)
         | 
| 50 | 
            +
             | 
| 51 | 
            +
                  return true if diff.any?
         | 
| 52 | 
            +
             | 
| 53 | 
            +
                  return false
         | 
| 54 | 
            +
                end
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                old != new
         | 
| 57 | 
            +
              end
         | 
| 58 | 
            +
             | 
| 59 | 
            +
              def excluded?(fact_name)
         | 
| 60 | 
            +
                @exclude_list.any? {|excluded_fact| fact_name =~ /#{excluded_fact}/}
         | 
| 61 | 
            +
              end
         | 
| 62 | 
            +
            end
         | 
| @@ -300,7 +300,7 @@ module Puppet::Util::FileParsing | |
| 300 300 | 
             
              def record_line(name, options, &block)
         | 
| 301 301 | 
             
                raise ArgumentError, _("Must include a list of fields") unless options.include?(:fields)
         | 
| 302 302 |  | 
| 303 | 
            -
                record = FileRecord.new(:record, options, &block)
         | 
| 303 | 
            +
                record = FileRecord.new(:record, **options, &block)
         | 
| 304 304 | 
             
                record.name = name.intern
         | 
| 305 305 |  | 
| 306 306 | 
             
                new_line_type(record)
         | 
| @@ -315,7 +315,7 @@ module Puppet::Util::FileParsing | |
| 315 315 | 
             
              def text_line(name, options, &block)
         | 
| 316 316 | 
             
                raise ArgumentError, _("You must provide a :match regex for text lines") unless options.include?(:match)
         | 
| 317 317 |  | 
| 318 | 
            -
                record = FileRecord.new(:text, options, &block)
         | 
| 318 | 
            +
                record = FileRecord.new(:text, **options, &block)
         | 
| 319 319 | 
             
                record.name = name.intern
         | 
| 320 320 |  | 
| 321 321 | 
             
                new_line_type(record)
         | 
    
        data/lib/puppet/util/posix.rb
    CHANGED
    
    | @@ -12,11 +12,18 @@ module Puppet::Util::POSIX | |
| 12 12 | 
             
              class << self
         | 
| 13 13 | 
             
                # Returns an array of all the groups that the user's a member of.
         | 
| 14 14 | 
             
                def groups_of(user)
         | 
| 15 | 
            -
                   | 
| 16 | 
            -
             | 
| 17 | 
            -
                    groups  | 
| 15 | 
            +
                  begin
         | 
| 16 | 
            +
                    require 'puppet/ffi/posix'
         | 
| 17 | 
            +
                    groups = get_groups_list(user)
         | 
| 18 | 
            +
                  rescue StandardError, LoadError => e
         | 
| 19 | 
            +
                    Puppet.debug("Falling back to Puppet::Etc.group: #{e.message}")
         | 
| 20 | 
            +
             | 
| 21 | 
            +
                    groups = []
         | 
| 22 | 
            +
                    Puppet::Etc.group do |group|
         | 
| 23 | 
            +
                      groups << group.name if group.mem.include?(user)
         | 
| 24 | 
            +
                    end
         | 
| 18 25 | 
             
                  end
         | 
| 19 | 
            -
             | 
| 26 | 
            +
             | 
| 20 27 | 
             
                  uniq_groups = groups.uniq
         | 
| 21 28 | 
             
                  if uniq_groups != groups
         | 
| 22 29 | 
             
                    Puppet.debug(_('Removing any duplicate group entries'))
         | 
| @@ -24,6 +31,39 @@ module Puppet::Util::POSIX | |
| 24 31 |  | 
| 25 32 | 
             
                  uniq_groups
         | 
| 26 33 | 
             
                end
         | 
| 34 | 
            +
             | 
| 35 | 
            +
                private
         | 
| 36 | 
            +
                def get_groups_list(user)
         | 
| 37 | 
            +
                  raise LoadError, "The 'getgrouplist' method is not available" unless Puppet::FFI::POSIX::Functions.respond_to?(:getgrouplist)
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                  user_gid = Puppet::Etc.getpwnam(user).gid
         | 
| 40 | 
            +
                  ngroups = Puppet::FFI::POSIX::Constants::MAXIMUM_NUMBER_OF_GROUPS
         | 
| 41 | 
            +
             | 
| 42 | 
            +
                  while true do # rubocop:disable Lint/LiteralInCondition
         | 
| 43 | 
            +
                    FFI::MemoryPointer.new(:int) do |ngroups_ptr|
         | 
| 44 | 
            +
                      FFI::MemoryPointer.new(:uint, ngroups) do |groups_ptr|
         | 
| 45 | 
            +
                        old_ngroups = ngroups
         | 
| 46 | 
            +
                        ngroups_ptr.write_int(ngroups)
         | 
| 47 | 
            +
             | 
| 48 | 
            +
                        if Puppet::FFI::POSIX::Functions::getgrouplist(user, user_gid, groups_ptr, ngroups_ptr) != -1
         | 
| 49 | 
            +
                          groups_gids = groups_ptr.get_array_of_uint(0, ngroups_ptr.read_int)
         | 
| 50 | 
            +
             | 
| 51 | 
            +
                          result = []
         | 
| 52 | 
            +
                          groups_gids.each do |group_gid|
         | 
| 53 | 
            +
                            group_info = Puppet::Etc.getgrgid(group_gid)
         | 
| 54 | 
            +
                            result |= [group_info.name] if group_info.mem.include?(user)
         | 
| 55 | 
            +
                          end
         | 
| 56 | 
            +
                          return result
         | 
| 57 | 
            +
                        end
         | 
| 58 | 
            +
             | 
| 59 | 
            +
                        ngroups = ngroups_ptr.read_int
         | 
| 60 | 
            +
                        if ngroups <= old_ngroups
         | 
| 61 | 
            +
                          ngroups *= 2
         | 
| 62 | 
            +
                        end
         | 
| 63 | 
            +
                      end
         | 
| 64 | 
            +
                    end
         | 
| 65 | 
            +
                  end
         | 
| 66 | 
            +
                end
         | 
| 27 67 | 
             
              end
         | 
| 28 68 |  | 
| 29 69 | 
             
              # Retrieve a field from a POSIX Etc object.  The id can be either an integer
         | 
| @@ -144,8 +184,17 @@ module Puppet::Util::POSIX | |
| 144 184 | 
             
                  name = get_posix_field(location, :name, id)
         | 
| 145 185 | 
             
                  check_value = name
         | 
| 146 186 | 
             
                end
         | 
| 187 | 
            +
             | 
| 147 188 | 
             
                if check_value != field
         | 
| 148 | 
            -
                   | 
| 189 | 
            +
                  check_value_id = get_posix_field(location, id_field, check_value) if check_value
         | 
| 190 | 
            +
             | 
| 191 | 
            +
                  if id == check_value_id
         | 
| 192 | 
            +
                    Puppet.debug("Multiple entries found for resource: '#{location}' with #{id_field}: #{id}")
         | 
| 193 | 
            +
                    return id
         | 
| 194 | 
            +
                  else
         | 
| 195 | 
            +
                    Puppet.debug("The value retrieved: '#{check_value}' is different than the required state: '#{field}', searching in all entries")
         | 
| 196 | 
            +
                    return search_posix_field(location, id_field, field)
         | 
| 197 | 
            +
                  end
         | 
| 149 198 | 
             
                else
         | 
| 150 199 | 
             
                  return id
         | 
| 151 200 | 
             
                end
         | 
| @@ -62,7 +62,7 @@ module Puppet::Util::ProviderFeatures | |
| 62 62 | 
             
                @features ||= {}
         | 
| 63 63 | 
             
                raise Puppet::DevError, _("Feature %{name} is already defined") % { name: name } if @features.include?(name)
         | 
| 64 64 | 
             
                begin
         | 
| 65 | 
            -
                  obj = ProviderFeature.new(name, docs, hash)
         | 
| 65 | 
            +
                  obj = ProviderFeature.new(name, docs, **hash)
         | 
| 66 66 | 
             
                  @features[obj.name] = obj
         | 
| 67 67 | 
             
                rescue ArgumentError => detail
         | 
| 68 68 | 
             
                  error = ArgumentError.new(
         | 
    
        data/lib/puppet/util/rubygems.rb
    CHANGED
    
    | @@ -41,7 +41,11 @@ module Puppet::Util::RubyGems | |
| 41 41 | 
             
                def directories
         | 
| 42 42 | 
             
                  # `require 'mygem'` will consider and potentially load
         | 
| 43 43 | 
             
                  # prerelease gems, so we need to match that behavior.
         | 
| 44 | 
            -
                   | 
| 44 | 
            +
                  #
         | 
| 45 | 
            +
                  # Just load the stub which points to the gem path, and
         | 
| 46 | 
            +
                  # delay loading the full specification until if/when the
         | 
| 47 | 
            +
                  # gem is required.
         | 
| 48 | 
            +
                  Gem::Specification.stubs.collect do |spec|
         | 
| 45 49 | 
             
                    File.join(spec.full_gem_path, 'lib')
         | 
| 46 50 | 
             
                  end
         | 
| 47 51 | 
             
                end
         | 
    
        data/lib/puppet/util/run_mode.rb
    CHANGED
    
    
    
        data/lib/puppet/util/windows.rb
    CHANGED
    
    
| @@ -19,15 +19,11 @@ module Puppet::Util::Windows::APITypes | |
| 19 19 |  | 
| 20 20 | 
             
              class ::FFI::Pointer
         | 
| 21 21 | 
             
                NULL_HANDLE = 0
         | 
| 22 | 
            +
                WCHAR_NULL = "\0\0".encode('UTF-16LE').freeze
         | 
| 22 23 |  | 
| 23 24 | 
             
                def self.from_string_to_wide_string(str, &block)
         | 
| 24 25 | 
             
                  str = Puppet::Util::Windows::String.wide_string(str)
         | 
| 25 | 
            -
                  FFI::MemoryPointer. | 
| 26 | 
            -
                    # uchar here is synonymous with byte
         | 
| 27 | 
            -
                    ptr.put_array_of_uchar(0, str.bytes.to_a)
         | 
| 28 | 
            -
             | 
| 29 | 
            -
                    yield ptr
         | 
| 30 | 
            -
                  end
         | 
| 26 | 
            +
                  FFI::MemoryPointer.from_wide_string(str, &block)
         | 
| 31 27 |  | 
| 32 28 | 
             
                  # ptr has already had free called, so nothing to return
         | 
| 33 29 | 
             
                  nil
         | 
| @@ -53,12 +49,18 @@ module Puppet::Util::Windows::APITypes | |
| 53 49 | 
             
                alias_method :read_word,  :read_uint16
         | 
| 54 50 | 
             
                alias_method :read_array_of_wchar, :read_array_of_uint16
         | 
| 55 51 |  | 
| 56 | 
            -
                def read_wide_string(char_length, dst_encoding = Encoding::UTF_8, encode_options = {})
         | 
| 52 | 
            +
                def read_wide_string(char_length, dst_encoding = Encoding::UTF_8, strip = false, encode_options = {})
         | 
| 57 53 | 
             
                  # char_length is number of wide chars (typically excluding NULLs), *not* bytes
         | 
| 58 54 | 
             
                  str = get_bytes(0, char_length * 2).force_encoding('UTF-16LE')
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                  if strip
         | 
| 57 | 
            +
                    i = str.index(WCHAR_NULL)
         | 
| 58 | 
            +
                    str = str[0, i] if i
         | 
| 59 | 
            +
                  end
         | 
| 60 | 
            +
             | 
| 59 61 | 
             
                  str.encode(dst_encoding, str.encoding, encode_options)
         | 
| 60 | 
            -
                rescue  | 
| 61 | 
            -
                  Puppet.debug "Unable to convert value #{str.nil? ? 'nil' : str.dump} to encoding #{dst_encoding} due to #{e.inspect}"
         | 
| 62 | 
            +
                rescue EncodingError => e
         | 
| 63 | 
            +
                  Puppet.debug { "Unable to convert value #{str.nil? ? 'nil' : str.dump} to encoding #{dst_encoding} due to #{e.inspect}" }
         | 
| 62 64 | 
             
                  raise
         | 
| 63 65 | 
             
                end
         | 
| 64 66 |  | 
| @@ -68,32 +70,31 @@ module Puppet::Util::Windows::APITypes | |
| 68 70 | 
             
                #   null_terminator = :double_null, then the terminating sequence is four bytes of zero.  This is UNIT32 = 0
         | 
| 69 71 | 
             
                # @param encode_options [Hash] Accepts the same option hash that may be passed to String#encode in Ruby
         | 
| 70 72 | 
             
                def read_arbitrary_wide_string_up_to(max_char_length = 512, null_terminator = :single_null, encode_options = {})
         | 
| 71 | 
            -
                   | 
| 72 | 
            -
             | 
| 73 | 
            -
             | 
| 74 | 
            -
             | 
| 75 | 
            -
             | 
| 76 | 
            -
             | 
| 77 | 
            -
             | 
| 78 | 
            -
             | 
| 79 | 
            -
             | 
| 80 | 
            -
             | 
| 81 | 
            -
             | 
| 82 | 
            -
             | 
| 83 | 
            -
             | 
| 84 | 
            -
             | 
| 73 | 
            +
                  idx = case null_terminator
         | 
| 74 | 
            +
                        when :single_null
         | 
| 75 | 
            +
                          # find index of wide null between 0 and max (exclusive)
         | 
| 76 | 
            +
                          (0...max_char_length).find do |i|
         | 
| 77 | 
            +
                            get_uint16(i * 2) == 0
         | 
| 78 | 
            +
                          end
         | 
| 79 | 
            +
                        when :double_null
         | 
| 80 | 
            +
                          # find index of double-wide null between 0 and max - 1 (exclusive)
         | 
| 81 | 
            +
                          (0...max_char_length - 1).find do |i|
         | 
| 82 | 
            +
                            get_uint32(i * 2) == 0
         | 
| 83 | 
            +
                          end
         | 
| 84 | 
            +
                        else
         | 
| 85 | 
            +
                          raise _("Unable to read wide strings with %{null_terminator} terminal nulls") % { null_terminator: null_terminator }
         | 
| 86 | 
            +
                        end
         | 
| 87 | 
            +
             | 
| 88 | 
            +
                  read_wide_string(idx || max_char_length, Encoding::UTF_8, false, encode_options)
         | 
| 85 89 | 
             
                end
         | 
| 86 90 |  | 
| 87 91 | 
             
                def read_win32_local_pointer(&block)
         | 
| 88 | 
            -
                  ptr =  | 
| 92 | 
            +
                  ptr = read_pointer
         | 
| 89 93 | 
             
                  begin
         | 
| 90 | 
            -
                    ptr = read_pointer
         | 
| 91 94 | 
             
                    yield ptr
         | 
| 92 95 | 
             
                  ensure
         | 
| 93 | 
            -
                    if ptr &&  | 
| 94 | 
            -
                       | 
| 95 | 
            -
                        Puppet.debug "LocalFree memory leak"
         | 
| 96 | 
            -
                      end
         | 
| 96 | 
            +
                    if !ptr.null? && FFI::WIN32::LocalFree(ptr.address) != FFI::Pointer::NULL_HANDLE
         | 
| 97 | 
            +
                      Puppet.debug "LocalFree memory leak"
         | 
| 97 98 | 
             
                    end
         | 
| 98 99 | 
             
                  end
         | 
| 99 100 |  | 
| @@ -102,23 +103,35 @@ module Puppet::Util::Windows::APITypes | |
| 102 103 | 
             
                end
         | 
| 103 104 |  | 
| 104 105 | 
             
                def read_com_memory_pointer(&block)
         | 
| 105 | 
            -
                  ptr =  | 
| 106 | 
            +
                  ptr = read_pointer
         | 
| 106 107 | 
             
                  begin
         | 
| 107 | 
            -
                    ptr = read_pointer
         | 
| 108 108 | 
             
                    yield ptr
         | 
| 109 109 | 
             
                  ensure
         | 
| 110 | 
            -
                    FFI::WIN32::CoTaskMemFree(ptr)  | 
| 110 | 
            +
                    FFI::WIN32::CoTaskMemFree(ptr) unless ptr.null?
         | 
| 111 111 | 
             
                  end
         | 
| 112 112 |  | 
| 113 113 | 
             
                  # ptr has already had CoTaskMemFree called, so nothing to return
         | 
| 114 114 | 
             
                  nil
         | 
| 115 115 | 
             
                end
         | 
| 116 116 |  | 
| 117 | 
            -
             | 
| 118 117 | 
             
                alias_method :write_dword, :write_uint32
         | 
| 119 118 | 
             
                alias_method :write_word, :write_uint16
         | 
| 120 119 | 
             
              end
         | 
| 121 120 |  | 
| 121 | 
            +
              class FFI::MemoryPointer
         | 
| 122 | 
            +
                # Return a MemoryPointer that points to wide string. This is analogous to the
         | 
| 123 | 
            +
                # FFI::MemoryPointer.from_string method.
         | 
| 124 | 
            +
                def self.from_wide_string(wstr)
         | 
| 125 | 
            +
                  ptr = FFI::MemoryPointer.new(:uchar, wstr.bytesize + 2)
         | 
| 126 | 
            +
                  ptr.put_array_of_uchar(0, wstr.bytes.to_a)
         | 
| 127 | 
            +
                  ptr.put_uint16(wstr.bytesize, 0)
         | 
| 128 | 
            +
             | 
| 129 | 
            +
                  yield ptr if block_given?
         | 
| 130 | 
            +
             | 
| 131 | 
            +
                  ptr
         | 
| 132 | 
            +
                end
         | 
| 133 | 
            +
              end
         | 
| 134 | 
            +
             | 
| 122 135 | 
             
              # FFI Types
         | 
| 123 136 | 
             
              # https://github.com/ffi/ffi/wiki/Types
         | 
| 124 137 |  | 
| @@ -183,6 +196,20 @@ module Puppet::Util::Windows::APITypes | |
| 183 196 | 
             
              FFI.typedef :uchar, :byte
         | 
| 184 197 | 
             
              FFI.typedef :uint16, :wchar
         | 
| 185 198 |  | 
| 199 | 
            +
              # Definitions for data types used in LSA structures and functions
         | 
| 200 | 
            +
              # https://docs.microsoft.com/en-us/windows/win32/api/ntsecapi/
         | 
| 201 | 
            +
              # https://docs.microsoft.com/sr-latn-rs/windows/win32/secmgmt/management-data-types
         | 
| 202 | 
            +
              FFI.typedef :pointer, :pwstr
         | 
| 203 | 
            +
              FFI.typedef :pointer, :pulong
         | 
| 204 | 
            +
              FFI.typedef :pointer, :lsa_handle
         | 
| 205 | 
            +
              FFI.typedef :pointer, :plsa_handle
         | 
| 206 | 
            +
              FFI.typedef :pointer, :psid
         | 
| 207 | 
            +
              FFI.typedef :pointer, :pvoid
         | 
| 208 | 
            +
              FFI.typedef :pointer, :plsa_unicode_string
         | 
| 209 | 
            +
              FFI.typedef :pointer, :plsa_object_attributes
         | 
| 210 | 
            +
              FFI.typedef :uint32,  :ntstatus
         | 
| 211 | 
            +
              FFI.typedef :dword,   :access_mask
         | 
| 212 | 
            +
             | 
| 186 213 | 
             
              module ::FFI::WIN32
         | 
| 187 214 | 
             
                extend ::FFI::Library
         | 
| 188 215 |  | 
| @@ -140,12 +140,7 @@ class Puppet::Util::Windows::EventLog | |
| 140 140 | 
             
              # @api private
         | 
| 141 141 | 
             
              def from_string_to_wide_string(str, &block)
         | 
| 142 142 | 
             
                str = wide_string(str)
         | 
| 143 | 
            -
                FFI::MemoryPointer. | 
| 144 | 
            -
                  # uchar here is synonymous with byte
         | 
| 145 | 
            -
                  ptr.put_array_of_uchar(0, str.bytes.to_a)
         | 
| 146 | 
            -
             | 
| 147 | 
            -
                  yield ptr
         | 
| 148 | 
            -
                end
         | 
| 143 | 
            +
                FFI::MemoryPointer.from_wide_string(str) { |ptr| yield ptr }
         | 
| 149 144 |  | 
| 150 145 | 
             
                # ptr has already had free called, so nothing to return
         | 
| 151 146 | 
             
                nil
         |