puppet 4.2.3 → 4.3.0
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.
- data/Gemfile +3 -0
- data/README.md +1 -1
- data/ext/debian/puppet.init +0 -1
- data/ext/debian/puppet.logrotate +14 -5
- data/ext/osx/puppet.plist +0 -2
- data/ext/redhat/client.init +13 -5
- data/ext/redhat/logrotate +15 -3
- data/ext/redhat/puppet.spec.erb +5 -1
- data/ext/redhat/server.init +1 -1
- data/ext/systemd/puppet.service +1 -0
- data/lib/puppet.rb +12 -0
- data/lib/puppet/agent.rb +4 -4
- data/lib/puppet/agent/locker.rb +11 -2
- data/lib/puppet/application/agent.rb +5 -1
- data/lib/puppet/application/apply.rb +4 -0
- data/lib/puppet/application/filebucket.rb +78 -4
- data/lib/puppet/application/lookup.rb +356 -0
- data/lib/puppet/application/master.rb +3 -0
- data/lib/puppet/configurer.rb +9 -5
- data/lib/puppet/context.rb +16 -1
- data/lib/puppet/context/trusted_information.rb +21 -1
- data/lib/puppet/daemon.rb +17 -13
- data/lib/puppet/data_binding.rb +4 -2
- data/lib/puppet/data_providers.rb +12 -13
- data/lib/puppet/data_providers/data_adapter.rb +7 -68
- data/lib/puppet/data_providers/data_function_support.rb +5 -26
- data/lib/puppet/data_providers/function_env_data_provider.rb +0 -10
- data/lib/puppet/data_providers/function_module_data_provider.rb +0 -22
- data/lib/puppet/data_providers/hiera_config.rb +106 -0
- data/lib/puppet/data_providers/hiera_env_data_provider.rb +18 -0
- data/lib/puppet/data_providers/hiera_interpolate.rb +97 -0
- data/lib/puppet/data_providers/hiera_module_data_provider.rb +23 -0
- data/lib/puppet/data_providers/hiera_support.rb +37 -0
- data/lib/puppet/data_providers/json_data_provider_factory.rb +31 -0
- data/lib/puppet/data_providers/lookup_adapter.rb +200 -0
- data/lib/puppet/data_providers/yaml_data_provider_factory.rb +32 -0
- data/lib/puppet/defaults.rb +12 -2
- data/lib/puppet/error.rb +4 -0
- data/lib/puppet/face/module/changes.rb +2 -1
- data/lib/puppet/feature/cfacter.rb +1 -0
- data/lib/puppet/file_bucket/dipper.rb +58 -2
- data/lib/puppet/functions.rb +2 -4
- data/lib/puppet/functions/assert_type.rb +48 -12
- data/lib/puppet/functions/defined.rb +79 -48
- data/lib/puppet/functions/each.rb +85 -27
- data/lib/puppet/functions/filter.rb +58 -23
- data/lib/puppet/functions/hiera.rb +76 -3
- data/lib/puppet/functions/hiera_array.rb +65 -3
- data/lib/puppet/functions/hiera_hash.rb +74 -2
- data/lib/puppet/functions/hiera_include.rb +75 -2
- data/lib/puppet/functions/lookup.rb +19 -17
- data/lib/puppet/functions/map.rb +56 -21
- data/lib/puppet/functions/match.rb +29 -12
- data/lib/puppet/functions/reduce.rb +95 -58
- data/lib/puppet/functions/versioncmp.rb +36 -0
- data/lib/puppet/functions/with.rb +15 -7
- data/lib/puppet/indirector/catalog/compiler.rb +3 -3
- data/lib/puppet/indirector/catalog/static_compiler.rb +46 -30
- data/lib/puppet/indirector/data_binding/none.rb +4 -1
- data/lib/puppet/indirector/file_bucket_file/file.rb +58 -1
- data/lib/puppet/indirector/hiera.rb +4 -0
- data/lib/puppet/indirector/json.rb +1 -1
- data/lib/puppet/indirector/msgpack.rb +1 -1
- data/lib/puppet/indirector/request.rb +7 -8
- data/lib/puppet/indirector/resource_type/parser.rb +5 -3
- data/lib/puppet/info_service.rb +7 -0
- data/lib/puppet/info_service/class_information_service.rb +111 -0
- data/lib/puppet/module_tool/metadata.rb +32 -9
- data/lib/puppet/module_tool/skeleton/templates/generator/README.md.erb +42 -38
- data/lib/puppet/network/authconfig.rb +21 -1
- data/lib/puppet/network/authorization.rb +8 -1
- data/lib/puppet/network/http/api/master/v3.rb +7 -1
- data/lib/puppet/network/http/api/master/v3/environment.rb +59 -0
- data/lib/puppet/node/environment.rb +9 -2
- data/lib/puppet/parser.rb +3 -0
- data/lib/puppet/parser/ast/pops_bridge.rb +39 -1
- data/lib/puppet/parser/compiler.rb +302 -12
- data/lib/puppet/parser/compiler/catalog_validator.rb +33 -0
- data/lib/puppet/parser/compiler/catalog_validator/env_relationship_validator.rb +64 -0
- data/lib/puppet/parser/compiler/catalog_validator/relationship_validator.rb +38 -0
- data/lib/puppet/parser/compiler/catalog_validator/site_validator.rb +20 -0
- data/lib/puppet/parser/environment_compiler.rb +165 -0
- data/lib/puppet/parser/functions/assert_type.rb +46 -16
- data/lib/puppet/parser/functions/defined.rb +105 -68
- data/lib/puppet/parser/functions/each.rb +85 -27
- data/lib/puppet/parser/functions/filter.rb +59 -23
- data/lib/puppet/parser/functions/hiera.rb +83 -27
- data/lib/puppet/parser/functions/hiera_array.rb +71 -28
- data/lib/puppet/parser/functions/hiera_hash.rb +81 -30
- data/lib/puppet/parser/functions/hiera_include.rb +81 -40
- data/lib/puppet/parser/functions/map.rb +55 -20
- data/lib/puppet/parser/functions/match.rb +27 -12
- data/lib/puppet/parser/functions/reduce.rb +97 -60
- data/lib/puppet/parser/functions/with.rb +16 -8
- data/lib/puppet/parser/resource.rb +98 -19
- data/lib/puppet/plugins/configuration.rb +3 -2
- data/lib/puppet/plugins/data_providers.rb +12 -60
- data/lib/puppet/plugins/data_providers/data_provider.rb +283 -0
- data/lib/puppet/plugins/data_providers/registry.rb +84 -0
- data/lib/puppet/pops.rb +19 -17
- data/lib/puppet/pops/adapters.rb +12 -0
- data/lib/puppet/pops/binder/binder.rb +2 -2
- data/lib/puppet/pops/binder/bindings_checker.rb +1 -1
- data/lib/puppet/pops/binder/bindings_label_provider.rb +3 -1
- data/lib/puppet/pops/binder/bindings_loader.rb +6 -2
- data/lib/puppet/pops/binder/bindings_model_meta.rb +2 -2
- data/lib/puppet/pops/binder/config/binder_config.rb +1 -1
- data/lib/puppet/pops/binder/injector.rb +4 -4
- data/lib/puppet/pops/binder/key_factory.rb +3 -9
- data/lib/puppet/pops/binder/scheme_handler/module_scheme.rb +68 -9
- data/lib/puppet/pops/evaluator/access_operator.rb +27 -60
- data/lib/puppet/pops/evaluator/closure.rb +8 -8
- data/lib/puppet/pops/evaluator/collectors/abstract_collector.rb +1 -1
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +5 -5
- data/lib/puppet/pops/evaluator/literal_evaluator.rb +87 -0
- data/lib/puppet/pops/evaluator/relationship_operator.rb +7 -1
- data/lib/puppet/pops/functions/dispatcher.rb +3 -3
- data/lib/puppet/pops/issues.rb +1 -1
- data/lib/puppet/pops/label_provider.rb +1 -1
- data/lib/puppet/pops/lookup.rb +25 -47
- data/lib/puppet/pops/lookup/explainer.rb +402 -0
- data/lib/puppet/pops/lookup/invocation.rb +117 -0
- data/lib/puppet/pops/merge_strategy.rb +73 -5
- data/lib/puppet/pops/model/factory.rb +34 -0
- data/lib/puppet/pops/model/model_label_provider.rb +10 -1
- data/lib/puppet/pops/model/model_meta.rb +15 -0
- data/lib/puppet/pops/model/model_tree_dumper.rb +18 -0
- data/lib/puppet/pops/parser/code_merger.rb +13 -1
- data/lib/puppet/pops/parser/egrammar.ra +56 -3
- data/lib/puppet/pops/parser/eparser.rb +1549 -1352
- data/lib/puppet/pops/parser/lexer2.rb +31 -6
- data/lib/puppet/pops/parser/locator.rb +1 -1
- data/lib/puppet/pops/parser/parser_support.rb +25 -13
- data/lib/puppet/pops/types/enumeration.rb +1 -2
- data/lib/puppet/pops/types/type_asserter.rb +16 -15
- data/lib/puppet/pops/types/type_assertion_error.rb +1 -0
- data/lib/puppet/pops/types/type_calculator.rb +171 -1020
- data/lib/puppet/pops/types/type_factory.rb +87 -148
- data/lib/puppet/pops/types/type_mismatch_describer.rb +743 -0
- data/lib/puppet/pops/types/type_parser.rb +116 -127
- data/lib/puppet/pops/types/types.rb +1394 -255
- data/lib/puppet/pops/types/types_meta.rb +0 -234
- data/lib/puppet/pops/validation.rb +7 -2
- data/lib/puppet/pops/validation/checker4_0.rb +28 -0
- data/lib/puppet/provider/augeas/augeas.rb +50 -0
- data/lib/puppet/provider/group/directoryservice.rb +10 -0
- data/lib/puppet/provider/package/dnf.rb +41 -0
- data/lib/puppet/provider/package/gem.rb +7 -2
- data/lib/puppet/provider/package/rpm.rb +1 -0
- data/lib/puppet/provider/package/windows/exe_package.rb +10 -8
- data/lib/puppet/provider/package/windows/msi_package.rb +4 -3
- data/lib/puppet/provider/package/windows/package.rb +9 -1
- data/lib/puppet/provider/package/yum.rb +14 -9
- data/lib/puppet/provider/service/bsd.rb +1 -1
- data/lib/puppet/provider/service/debian.rb +21 -0
- data/lib/puppet/provider/service/init.rb +6 -0
- data/lib/puppet/provider/service/rcng.rb +51 -0
- data/lib/puppet/provider/service/redhat.rb +2 -1
- data/lib/puppet/provider/service/smf.rb +43 -2
- data/lib/puppet/provider/service/src.rb +27 -0
- data/lib/puppet/provider/service/systemd.rb +15 -3
- data/lib/puppet/provider/sshkey/parsed.rb +19 -9
- data/lib/puppet/reference/report.rb +9 -12
- data/lib/puppet/reports.rb +5 -1
- data/lib/puppet/resource.rb +50 -73
- data/lib/puppet/resource/capability_finder.rb +95 -0
- data/lib/puppet/resource/catalog.rb +47 -7
- data/lib/puppet/resource/status.rb +0 -2
- data/lib/puppet/resource/type.rb +238 -44
- data/lib/puppet/resource/type_collection.rb +60 -2
- data/lib/puppet/settings.rb +2 -2
- data/lib/puppet/ssl/certificate_authority/interface.rb +2 -2
- data/lib/puppet/ssl/oids.rb +9 -1
- data/lib/puppet/transaction.rb +4 -1
- data/lib/puppet/transaction/additional_resource_generator.rb +71 -8
- data/lib/puppet/transaction/resource_harness.rb +9 -4
- data/lib/puppet/type.rb +74 -3
- data/lib/puppet/type/augeas.rb +8 -0
- data/lib/puppet/type/file/source.rb +14 -12
- data/lib/puppet/type/user.rb +4 -2
- data/lib/puppet/util/windows/security.rb +4 -1
- data/lib/puppet/util/windows/taskscheduler.rb +1 -1
- data/lib/puppet/version.rb +1 -1
- data/spec/fixtures/unit/application/environments/production/data/common.yaml +3 -0
- data/spec/fixtures/unit/application/environments/production/environment.conf +1 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_json/data/bad.json +3 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_json/environment.conf +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_json/hiera.yaml +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_json/manifests/site.pp +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_yaml/data/bad.yaml +3 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_yaml/environment.conf +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_yaml/hiera.yaml +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_bad_syntax_yaml/manifests/site.pp +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_defaults/data/common.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_defaults/environment.conf +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_defaults/manifests/site.pp +1 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_defaults/modules/one/data/common.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_defaults/modules/one/manifests/init.pp +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_defaults/modules/one/metadata.json +9 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/data1/first.json +3 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/data1/name.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/data1/second.json +3 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/data1/single.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/data2/single.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/environment.conf +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/hiera.yaml +18 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_env_config/manifests/site.pp +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_misc/data/common.yaml +46 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_misc/environment.conf +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_misc/manifests/site.pp +1 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_misc/modules/one/data/common.yaml +30 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_misc/modules/one/manifests/init.pp +13 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_misc/modules/one/metadata.json +9 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/environment.conf +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/manifests/site.pp +1 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/data1/first.json +3 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/data1/name.yaml +1 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/data1/second.json +3 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/data1/single.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/data2/single.yaml +2 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/hiera.yaml +18 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/manifests/init.pp +5 -0
- data/spec/fixtures/unit/data_providers/environments/hiera_module_config/modules/one/metadata.json +9 -0
- data/spec/fixtures/unit/data_providers/environments/sample/modules/dataprovider/lib/puppet_x/helindbe/sample_env_data.rb +1 -0
- data/spec/fixtures/unit/data_providers/environments/sample/modules/dataprovider/lib/puppet_x/helindbe/sample_module_data.rb +1 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/hieraprovider/data/first.json +3 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/hieraprovider/hiera.yaml +8 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/hieraprovider/manifests/init.pp +5 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/hieraprovider/metadata.json +9 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/meta/lib/puppet/functions/meta/data.rb +9 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/meta/manifests/init.pp +3 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/meta/metadata.json +9 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/metawcp/lib/puppet/bindings/metawcp/default.rb +10 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/metawcp/lib/puppet_x/thallgren/sample_module_data.rb +23 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/metawcp/manifests/init.pp +3 -0
- data/spec/fixtures/unit/functions/lookup/environments/production/modules/metawcp/metadata.json +9 -0
- data/spec/fixtures/unit/provider/package/yum/yum-check-update-security.txt +184 -0
- data/spec/fixtures/vcr/cassettes/Puppet_Network_HTTP_Connection/when_handling_requests/_request_get/should_yield_to_the_block.yml +24 -0
- data/spec/fixtures/vcr/cassettes/Puppet_Network_HTTP_Connection/when_handling_requests/_request_head/should_yield_to_the_block.yml +24 -0
- data/spec/fixtures/vcr/cassettes/Puppet_Network_HTTP_Connection/when_handling_requests/_request_post/should_yield_to_the_block.yml +24 -0
- data/spec/integration/data_binding_spec.rb +229 -0
- data/spec/integration/file_bucket/file_spec.rb +2 -2
- data/spec/integration/parser/compiler_spec.rb +23 -19
- data/spec/integration/parser/resource_expressions_spec.rb +4 -4
- data/spec/integration/parser/undef_param_spec.rb +1 -1
- data/spec/integration/resource/catalog_spec.rb +1 -1
- data/spec/integration/type/package_spec.rb +2 -0
- data/spec/integration/util/windows/security_spec.rb +18 -0
- data/spec/lib/matchers/include_in_order.rb +2 -2
- data/spec/shared_behaviours/iterative_functions.rb +8 -8
- data/spec/spec_helper.rb +7 -0
- data/spec/unit/agent/locker_spec.rb +4 -4
- data/spec/unit/agent_spec.rb +0 -8
- data/spec/unit/application/agent_spec.rb +5 -0
- data/spec/unit/application/apply_spec.rb +8 -0
- data/spec/unit/application/filebucket_spec.rb +87 -1
- data/spec/unit/application/lookup_spec.rb +195 -0
- data/spec/unit/appmgmt_spec.rb +657 -0
- data/spec/unit/capability_spec.rb +414 -0
- data/spec/unit/configurer_spec.rb +7 -1
- data/spec/unit/context/trusted_information_spec.rb +24 -1
- data/spec/unit/daemon_spec.rb +18 -8
- data/spec/unit/data_providers/hiera_data_provider_spec.rb +201 -0
- data/spec/unit/file_bucket/dipper_spec.rb +210 -1
- data/spec/unit/functions/assert_type_spec.rb +5 -7
- data/spec/unit/functions/defined_spec.rb +2 -2
- data/spec/unit/functions/epp_spec.rb +2 -2
- data/spec/unit/functions/lookup_spec.rb +200 -9
- data/spec/unit/functions/regsubst_spec.rb +17 -8
- data/spec/unit/functions/scanf_spec.rb +1 -1
- data/spec/unit/functions/split_spec.rb +2 -2
- data/spec/unit/functions/versioncmp_spec.rb +36 -0
- data/spec/unit/functions4_spec.rb +58 -72
- data/spec/unit/indirector/catalog/compiler_spec.rb +28 -8
- data/spec/unit/indirector/catalog/static_compiler_spec.rb +38 -20
- data/spec/unit/indirector/data_binding/none_spec.rb +2 -2
- data/spec/unit/indirector/file_bucket_file/file_spec.rb +52 -1
- data/spec/unit/indirector/request_spec.rb +8 -8
- data/spec/unit/info_service_spec.rb +236 -0
- data/spec/unit/module_tool/metadata_spec.rb +31 -2
- data/spec/unit/network/authconfig_spec.rb +62 -32
- data/spec/unit/network/authorization_spec.rb +30 -2
- data/spec/unit/network/http/connection_spec.rb +14 -19
- data/spec/unit/parser/compiler_spec.rb +86 -2
- data/spec/unit/parser/functions/create_resources_spec.rb +1 -1
- data/spec/unit/parser/resource_spec.rb +2 -20
- data/spec/unit/pops/binder/config/binder_config_spec.rb +1 -1
- data/spec/unit/pops/binder/injector_spec.rb +3 -3
- data/spec/unit/pops/evaluator/access_ops_spec.rb +13 -11
- data/spec/unit/pops/evaluator/basic_expressions_spec.rb +1 -2
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +19 -11
- data/spec/unit/pops/evaluator/literal_evaluator_spec.rb +43 -0
- data/spec/unit/pops/label_provider_spec.rb +5 -1
- data/spec/unit/pops/parser/lexer2_spec.rb +33 -7
- data/spec/unit/pops/parser/parse_application_spec.rb +40 -0
- data/spec/unit/pops/parser/parse_basic_expressions_spec.rb +4 -0
- data/spec/unit/pops/parser/parse_capabilities_spec.rb +47 -0
- data/spec/unit/pops/parser/parse_site_spec.rb +38 -0
- data/spec/unit/pops/parser/parser_rspec_helper.rb +5 -0
- data/spec/unit/pops/parser/parser_spec.rb +18 -0
- data/spec/unit/pops/types/type_calculator_spec.rb +427 -444
- data/spec/unit/pops/types/type_factory_spec.rb +12 -12
- data/spec/unit/pops/types/type_parser_spec.rb +7 -12
- data/spec/unit/pops/validator/validator_spec.rb +25 -0
- data/spec/unit/provider/augeas/augeas_spec.rb +50 -0
- data/spec/unit/provider/group/directoryservice_spec.rb +33 -0
- data/spec/unit/provider/group/windows_adsi_spec.rb +3 -0
- data/spec/unit/provider/package/dnf_spec.rb +92 -0
- data/spec/unit/provider/package/gem_spec.rb +7 -0
- data/spec/unit/provider/package/rpm_spec.rb +25 -2
- data/spec/unit/provider/package/windows/package_spec.rb +41 -0
- data/spec/unit/provider/package/yum_spec.rb +21 -13
- data/spec/unit/provider/scheduled_task/win32_taskscheduler_spec.rb +10 -0
- data/spec/unit/provider/service/debian_spec.rb +27 -0
- data/spec/unit/provider/service/rcng_spec.rb +41 -0
- data/spec/unit/provider/service/redhat_spec.rb +8 -1
- data/spec/unit/provider/service/smf_spec.rb +30 -5
- data/spec/unit/provider/service/src_spec.rb +19 -4
- data/spec/unit/provider/service/systemd_spec.rb +78 -29
- data/spec/unit/provider/sshkey/parsed_spec.rb +23 -0
- data/spec/unit/reports_spec.rb +10 -0
- data/spec/unit/resource/capability_finder_spec.rb +56 -0
- data/spec/unit/resource/catalog_spec.rb +31 -8
- data/spec/unit/resource/type_collection_spec.rb +23 -2
- data/spec/unit/resource/type_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +22 -4
- data/spec/unit/settings_spec.rb +90 -1
- data/spec/unit/ssl/certificate_authority/interface_spec.rb +4 -3
- data/spec/unit/ssl/oids_spec.rb +8 -0
- data/spec/unit/transaction/additional_resource_generator_spec.rb +78 -5
- data/spec/unit/transaction/report_spec.rb +24 -1
- data/spec/unit/type/package_spec.rb +1 -0
- data/spec/unit/type/user_spec.rb +14 -7
- data/spec/unit/type_spec.rb +1 -1
- metadata +169 -5
- data/lib/puppet/pops/evaluator/callable_mismatch_describer.rb +0 -175
- data/spec/integration/data_binding.rb +0 -104
@@ -3,41 +3,99 @@ Puppet::Parser::Functions::newfunction(
|
|
3
3
|
:type => :rvalue,
|
4
4
|
:arity => -3,
|
5
5
|
:doc => <<-DOC
|
6
|
-
|
7
|
-
|
6
|
+
Runs a [lambda](http://docs.puppetlabs.com/puppet/latest/reference/lang_lambdas.html)
|
7
|
+
repeatedly using each value in a data structure, then returns the values unchanged.
|
8
8
|
|
9
|
-
This function takes two mandatory arguments
|
10
|
-
of enumerable type (integer, Integer range, or String), and the second
|
11
|
-
a parameterized block as produced by the puppet syntax:
|
9
|
+
This function takes two mandatory arguments, in this order:
|
12
10
|
|
13
|
-
|
14
|
-
|
11
|
+
1. An array or hash the function will iterate over.
|
12
|
+
2. A lambda, which the function calls for each element in the first argument. It can
|
13
|
+
request one or two parameters.
|
15
14
|
|
16
|
-
|
17
|
-
should define one or two block parameters.
|
18
|
-
For each application of the block, the next element from the array is selected, and it is passed to
|
19
|
-
the block if the block has one parameter. If the block has two parameters, the first is the elements
|
20
|
-
index, and the second the value. The index starts from 0.
|
15
|
+
**Example**: Using the `each` function
|
21
16
|
|
22
|
-
|
23
|
-
each($a) |$index, $value| { ... }
|
17
|
+
`$data.each |$parameter| { <PUPPET CODE BLOCK> }`
|
24
18
|
|
25
|
-
|
26
|
-
When one parameter is defined, the iteration is performed with each entry as an array of `[key, value]`,
|
27
|
-
and when two parameters are defined the iteration is performed with key and value.
|
19
|
+
or
|
28
20
|
|
29
|
-
|
30
|
-
$a.each |$key, $value| { ..."key ${key}, value ${value}" }
|
21
|
+
`each($data) |$parameter| { <PUPPET CODE BLOCK> }`
|
31
22
|
|
32
|
-
|
23
|
+
When the first argument (`$data` in the above example) is an array, Puppet passes each
|
24
|
+
value in turn to the lambda, then returns the original values.
|
33
25
|
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
26
|
+
**Example**: Using the `each` function with an array and a one-parameter lambda
|
27
|
+
|
28
|
+
~~~ puppet
|
29
|
+
# For the array $data, run a lambda that creates a resource for each item.
|
30
|
+
$data = ["routers", "servers", "workstations"]
|
31
|
+
$data.each |$item| {
|
32
|
+
notify { $item:
|
33
|
+
message => $item
|
34
|
+
}
|
35
|
+
}
|
36
|
+
# Puppet creates one resource for each of the three items in $data. Each resource is
|
37
|
+
# named after the item's value and uses the item's value in a parameter.
|
38
|
+
~~~
|
39
|
+
|
40
|
+
When the first argument is a hash, Puppet passes each key and value pair to the lambda
|
41
|
+
as an array in the form `[key, value]` and returns the original hash.
|
42
|
+
|
43
|
+
**Example**: Using the `each` function with a hash and a one-parameter lambda
|
44
|
+
|
45
|
+
~~~ puppet
|
46
|
+
# For the hash $data, run a lambda using each item as a key-value array that creates a
|
47
|
+
# resource for each item.
|
48
|
+
$data = {"rtr" => "Router", "svr" => "Server", "wks" => "Workstation"}
|
49
|
+
$data.each |$items| {
|
50
|
+
notify { $items[0]:
|
51
|
+
message => $items[1]
|
52
|
+
}
|
53
|
+
}
|
54
|
+
# Puppet creates one resource for each of the three items in $data, each named after the
|
55
|
+
# item's key and containing a parameter using the item's value.
|
56
|
+
~~~
|
57
|
+
|
58
|
+
When the first argument is an array and the lambda has two parameters, Puppet passes the
|
59
|
+
array's indexes (enumerated from 0) in the first parameter and its values in the second
|
60
|
+
parameter.
|
61
|
+
|
62
|
+
**Example**: Using the `each` function with an array and a two-parameter lambda
|
63
|
+
|
64
|
+
~~~ puppet
|
65
|
+
# For the array $data, run a lambda using each item's index and value that creates a
|
66
|
+
# resource for each item.
|
67
|
+
$data = ["routers", "servers", "workstations"]
|
68
|
+
$data.each |$index, $value| {
|
69
|
+
notify { $value:
|
70
|
+
message => $index
|
71
|
+
}
|
72
|
+
}
|
73
|
+
# Puppet creates one resource for each of the three items in $data, each named after the
|
74
|
+
# item's value and containing a parameter using the item's index.
|
75
|
+
~~~
|
76
|
+
|
77
|
+
When the first argument is a hash, Puppet passes its keys to the first parameter and its
|
78
|
+
values to the second parameter.
|
79
|
+
|
80
|
+
**Example**: Using the `each` function with a hash and a two-parameter lambda
|
81
|
+
|
82
|
+
~~~ puppet
|
83
|
+
# For the hash $data, run a lambda using each item's key and value to create a resource
|
84
|
+
# for each item.
|
85
|
+
$data = {"rtr" => "Router", "svr" => "Server", "wks" => "Workstation"}
|
86
|
+
$data.each |$key, $value| {
|
87
|
+
notify { $key:
|
88
|
+
message => $value
|
89
|
+
}
|
90
|
+
}
|
91
|
+
# Puppet creates one resource for each of the three items in $data, each named after the
|
92
|
+
# item's key and containing a parameter using the item's value.
|
93
|
+
~~~
|
94
|
+
|
95
|
+
For an example that demonstrates how to create multiple `file` resources using `each`,
|
96
|
+
see the Puppet
|
97
|
+
[iteration](https://docs.puppetlabs.com/puppet/latest/reference/lang_iteration.html)
|
98
|
+
documentation.
|
41
99
|
|
42
100
|
- Since 4.0.0
|
43
101
|
DOC
|
@@ -1,39 +1,75 @@
|
|
1
1
|
Puppet::Parser::Functions::newfunction(
|
2
2
|
:filter,
|
3
|
+
:type => :rvalue,
|
3
4
|
:arity => -3,
|
4
5
|
:doc => <<-DOC
|
5
|
-
|
6
|
-
|
7
|
-
|
6
|
+
Applies a [lambda](http://docs.puppetlabs.com/puppet/latest/reference/lang_lambdas.html)
|
7
|
+
to every value in a data structure and returns an array or hash containing any elements
|
8
|
+
for which the lambda evaluates to `true`.
|
8
9
|
|
9
|
-
|
10
|
-
Enumerable object (integer, Integer range, or String),
|
11
|
-
and the second a parameterized block as produced by the puppet syntax:
|
10
|
+
This function takes two mandatory arguments, in this order:
|
12
11
|
|
13
|
-
|
14
|
-
|
12
|
+
1. An array or hash the function will iterate over.
|
13
|
+
2. A lambda, which the function calls for each element in the first argument. It can
|
14
|
+
request one or two parameters.
|
15
15
|
|
16
|
-
|
17
|
-
When the first argument is a Hash the entry is an array with `[key, value]`.
|
16
|
+
**Example**: Using the `filter` function
|
18
17
|
|
19
|
-
|
18
|
+
`$filtered_data = $data.filter |$parameter| { <PUPPET CODE BLOCK> }`
|
20
19
|
|
21
|
-
|
22
|
-
$a = ["raspberry", "blueberry", "orange"]
|
23
|
-
$a.filter |$x| { $x =~ /berry$/ } # rasberry, blueberry
|
20
|
+
or
|
24
21
|
|
25
|
-
|
26
|
-
enumerables except Hash, and to `key, value` for a Hash.
|
22
|
+
`$filtered_data = filter($data) |$parameter| { <PUPPET CODE BLOCK> }`
|
27
23
|
|
28
|
-
|
24
|
+
When the first argument (`$data` in the above example) is an array, Puppet passes each
|
25
|
+
value in turn to the lambda and returns an array containing the results.
|
29
26
|
|
30
|
-
|
31
|
-
$a = ["raspberry", "blueberry", "orange"]
|
32
|
-
$a.filter |$index, $x| { $index % 2 == 0 and $x =~ /berry$/ } # raspberry
|
27
|
+
**Example**: Using the `filter` function with an array and a one-parameter lambda
|
33
28
|
|
34
|
-
|
35
|
-
|
36
|
-
|
29
|
+
~~~ puppet
|
30
|
+
# For the array $data, return an array containing the values that end with "berry"
|
31
|
+
$data = ["orange", "blueberry", "raspberry"]
|
32
|
+
$filtered_data = $data.filter |$items| { $items =~ /berry$/ }
|
33
|
+
# $filtered_data = [blueberry, raspberry]
|
34
|
+
~~~
|
35
|
+
|
36
|
+
When the first argument is a hash, Puppet passes each key and value pair to the lambda
|
37
|
+
as an array in the form `[key, value]` and returns a hash containing the results.
|
38
|
+
|
39
|
+
**Example**: Using the `filter` function with a hash and a one-parameter lambda
|
40
|
+
|
41
|
+
~~~ puppet
|
42
|
+
# For the hash $data, return a hash containing all values of keys that end with "berry"
|
43
|
+
$data = { "orange" => 0, "blueberry" => 1, "raspberry" => 2 }
|
44
|
+
$filtered_data = $data.filter |$items| { $items[0] =~ /berry$/ }
|
45
|
+
# $filtered_data = {blueberry => 1, raspberry => 2}
|
46
|
+
|
47
|
+
When the first argument is an array and the lambda has two parameters, Puppet passes the
|
48
|
+
array's indexes (enumerated from 0) in the first parameter and its values in the second
|
49
|
+
parameter.
|
50
|
+
|
51
|
+
**Example**: Using the `filter` function with an array and a two-parameter lambda
|
52
|
+
|
53
|
+
~~~ puppet
|
54
|
+
# For the array $data, return an array of all keys that both end with "berry" and have
|
55
|
+
# an even-numbered index
|
56
|
+
$data = ["orange", "blueberry", "raspberry"]
|
57
|
+
$filtered_data = $data.filter |$indexes, $values| { $indexes % 2 == 0 and $values =~ /berry$/ }
|
58
|
+
# $filtered_data = [raspberry]
|
59
|
+
~~~
|
60
|
+
|
61
|
+
When the first argument is a hash, Puppet passes its keys to the first parameter and its
|
62
|
+
values to the second parameter.
|
63
|
+
|
64
|
+
**Example**: Using the `filter` function with a hash and a two-parameter lambda
|
65
|
+
|
66
|
+
~~~ puppet
|
67
|
+
# For the hash $data, return a hash of all keys that both end with "berry" and have
|
68
|
+
# values less than or equal to 1
|
69
|
+
$data = { "orange" => 0, "blueberry" => 1, "raspberry" => 2 }
|
70
|
+
$filtered_data = $data.filter |$keys, $values| { $keys =~ /berry$/ and $values <= 1 }
|
71
|
+
# $filtered_data = {blueberry => 1}
|
72
|
+
~~~
|
37
73
|
|
38
74
|
- Since 4.0.0
|
39
75
|
DOC
|
@@ -1,33 +1,89 @@
|
|
1
1
|
require 'hiera_puppet'
|
2
2
|
|
3
3
|
module Puppet::Parser::Functions
|
4
|
-
newfunction(
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
4
|
+
newfunction(
|
5
|
+
:hiera,
|
6
|
+
:type => :rvalue,
|
7
|
+
:arity => -2,
|
8
|
+
:doc => <<DOC
|
9
|
+
Performs a standard priority lookup of the hierarchy and returns the most specific value
|
10
|
+
for a given key. The returned value can be any type of data.
|
11
|
+
|
12
|
+
The function takes up to three arguments, in this order:
|
13
|
+
|
14
|
+
1. A string key that Hiera searches for in the hierarchy. **Required**.
|
15
|
+
2. An optional default value to return if Hiera doesn't find anything matching the key.
|
16
|
+
* If this argument isn't provided and this function results in a lookup failure, Puppet
|
17
|
+
fails with a compilation error.
|
18
|
+
3. The optional name of an arbitrary
|
19
|
+
[hierarchy level](https://docs.puppetlabs.com/hiera/latest/hierarchy.html) to insert at the
|
20
|
+
top of the hierarchy. This lets you temporarily modify the hierarchy for a single lookup.
|
21
|
+
* If Hiera doesn't find a matching key in the overriding hierarchy level, it continues
|
22
|
+
searching the rest of the hierarchy.
|
23
|
+
|
24
|
+
The `hiera` function does **not** find all matches throughout a hierarchy, instead
|
25
|
+
returining the first specific value starting at the top of the hierarchy. To search
|
26
|
+
throughout a hierarchy, use the `hiera_array` or `hiera_hash` functions.
|
27
|
+
|
28
|
+
**Example**: Using `hiera`
|
29
|
+
|
30
|
+
~~~ yaml
|
31
|
+
# Assuming hiera.yaml
|
32
|
+
# :hierarchy:
|
33
|
+
# - web01.example.com
|
34
|
+
# - common
|
35
|
+
|
36
|
+
# Assuming web01.example.com.yaml:
|
37
|
+
# users:
|
38
|
+
# - "Amy Barry"
|
39
|
+
# - "Carrie Douglas"
|
40
|
+
|
41
|
+
# Assuming common.yaml:
|
42
|
+
users:
|
43
|
+
admins:
|
44
|
+
- "Edith Franklin"
|
45
|
+
- "Ginny Hamilton"
|
46
|
+
regular:
|
47
|
+
- "Iris Jackson"
|
48
|
+
- "Kelly Lambert"
|
49
|
+
~~~
|
50
|
+
|
51
|
+
~~~ puppet
|
52
|
+
# Assuming we are not web01.example.com:
|
53
|
+
|
54
|
+
$users = hiera('users', undef)
|
55
|
+
|
56
|
+
# $users contains {admins => ["Edith Franklin", "Ginny Hamilton"],
|
57
|
+
# regular => ["Iris Jackson", "Kelly Lambert"]}
|
58
|
+
~~~
|
59
|
+
|
60
|
+
You can optionally generate the default value with a
|
61
|
+
[lambda](https://docs.puppetlabs.com/puppet/latest/reference/lang_lambdas.html) that
|
62
|
+
takes one parameter.
|
63
|
+
|
64
|
+
**Example**: Using `hiera` with a lambda
|
65
|
+
|
66
|
+
~~~ puppet
|
67
|
+
# Assuming the same Hiera data as the previous example:
|
68
|
+
|
69
|
+
$users = hiera('users') | $key | { "Key \'${key}\' not found" }
|
70
|
+
|
71
|
+
# $users contains {admins => ["Edith Franklin", "Ginny Hamilton"],
|
72
|
+
# regular => ["Iris Jackson", "Kelly Lambert"]}
|
73
|
+
# If hiera couldn't match its key, it would return the lambda result,
|
74
|
+
# "Key 'users' not found".
|
75
|
+
~~~
|
76
|
+
|
77
|
+
The returned value's data type depends on the types of the results. In the example
|
78
|
+
above, Hiera matches the 'users' key and returns it as a hash.
|
79
|
+
|
80
|
+
See
|
81
|
+
[the documentation](https://docs.puppetlabs.com/hiera/latest/puppet.html#hiera-lookup-functions)
|
82
|
+
for more information about Hiera lookup functions.
|
83
|
+
|
84
|
+
- Since 4.0.0
|
85
|
+
DOC
|
86
|
+
) do |*args|
|
30
87
|
function_fail(["hiera() has been converted to 4x API"])
|
31
88
|
end
|
32
89
|
end
|
33
|
-
|
@@ -1,34 +1,77 @@
|
|
1
1
|
require 'hiera_puppet'
|
2
2
|
|
3
3
|
module Puppet::Parser::Functions
|
4
|
-
newfunction(
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
4
|
+
newfunction(
|
5
|
+
:hiera_array,
|
6
|
+
:type => :rvalue,
|
7
|
+
:arity => -2,
|
8
|
+
:doc => <<-DOC
|
9
|
+
Finds all matches of a key throughout the hierarchy and returns them as a single flattened
|
10
|
+
array of unique values. If any of the matched values are arrays, they're flattened and
|
11
|
+
included in the results. This is called an
|
12
|
+
[array merge lookup](https://docs.puppetlabs.com/hiera/latest/lookup_types.html#array-merge).
|
13
|
+
|
14
|
+
The `hiera_array` function takes up to three arguments, in this order:
|
15
|
+
|
16
|
+
1. A string key that Hiera searches for in the hierarchy. **Required**.
|
17
|
+
2. An optional default value to return if Hiera doesn't find anything matching the key.
|
18
|
+
* If this argument isn't provided and this function results in a lookup failure, Puppet
|
19
|
+
fails with a compilation error.
|
20
|
+
3. The optional name of an arbitrary
|
21
|
+
[hierarchy level](https://docs.puppetlabs.com/hiera/latest/hierarchy.html) to insert at the
|
22
|
+
top of the hierarchy. This lets you temporarily modify the hierarchy for a single lookup.
|
23
|
+
* If Hiera doesn't find a matching key in the overriding hierarchy level, it continues
|
24
|
+
searching the rest of the hierarchy.
|
25
|
+
|
26
|
+
**Example**: Using `hiera_array`
|
27
|
+
|
28
|
+
~~~ yaml
|
29
|
+
# Assuming hiera.yaml
|
30
|
+
# :hierarchy:
|
31
|
+
# - web01.example.com
|
32
|
+
# - common
|
33
|
+
|
34
|
+
# Assuming common.yaml:
|
35
|
+
# users:
|
36
|
+
# - 'cdouglas = regular'
|
37
|
+
# - 'efranklin = regular'
|
38
|
+
|
39
|
+
# Assuming web01.example.com.yaml:
|
40
|
+
# users: 'abarry = admin'
|
41
|
+
~~~
|
42
|
+
|
43
|
+
~~~ puppet
|
44
|
+
$allusers = hiera_array('users', undef)
|
45
|
+
|
46
|
+
# $allusers contains ["cdouglas = regular", "efranklin = regular", "abarry = admin"].
|
47
|
+
~~~
|
48
|
+
|
49
|
+
You can optionally generate the default value with a
|
50
|
+
[lambda](https://docs.puppetlabs.com/puppet/latest/reference/lang_lambdas.html) that
|
51
|
+
takes one parameter.
|
52
|
+
|
53
|
+
**Example**: Using `hiera_array` with a lambda
|
54
|
+
|
55
|
+
~~~ puppet
|
56
|
+
# Assuming the same Hiera data as the previous example:
|
57
|
+
|
58
|
+
$allusers = hiera_array('users') | $key | { "Key \'${key}\' not found" }
|
59
|
+
|
60
|
+
# $allusers contains ["cdouglas = regular", "efranklin = regular", "abarry = admin"].
|
61
|
+
# If hiera_array couldn't match its key, it would return the lambda result,
|
62
|
+
# "Key 'users' not found".
|
63
|
+
~~~
|
64
|
+
|
65
|
+
`hiera_array` expects that all values returned will be strings or arrays. If any matched
|
66
|
+
value is a hash, Puppet raises a type mismatch error.
|
67
|
+
|
68
|
+
See
|
69
|
+
[the documentation](https://docs.puppetlabs.com/hiera/latest/puppet.html#hiera-lookup-functions)
|
70
|
+
for more information about Hiera lookup functions.
|
71
|
+
|
72
|
+
- Since 4.0.0
|
73
|
+
DOC
|
74
|
+
) do |*args|
|
32
75
|
function_fail(["hiera_array() has been converted to 4x API"])
|
33
76
|
end
|
34
77
|
end
|
@@ -1,36 +1,87 @@
|
|
1
1
|
require 'hiera_puppet'
|
2
2
|
|
3
3
|
module Puppet::Parser::Functions
|
4
|
-
newfunction(
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
4
|
+
newfunction(
|
5
|
+
:hiera_hash,
|
6
|
+
:type => :rvalue,
|
7
|
+
:arity => -2,
|
8
|
+
:doc => <<-DOC
|
9
|
+
Finds all matches of a key throughout the hierarchy and returns them in a merged hash.
|
10
|
+
If any of the matched hashes share keys, the final hash uses the value from the
|
11
|
+
highest priority match. This is called a
|
12
|
+
[hash merge lookup](https://docs.puppetlabs.com/hiera/latest/lookup_types.html#hash-merge).
|
13
|
+
|
14
|
+
The merge strategy is determined by Hiera's
|
15
|
+
[`:merge_behavior`](https://docs.puppetlabs.com/hiera/latest/configuring.html#mergebehavior)
|
16
|
+
setting.
|
17
|
+
|
18
|
+
The `hiera_hash` function takes up to three arguments, in this order:
|
19
|
+
|
20
|
+
1. A string key that Hiera searches for in the hierarchy. **Required**.
|
21
|
+
2. An optional default value to return if Hiera doesn't find anything matching the key.
|
22
|
+
* If this argument isn't provided and this function results in a lookup failure, Puppet
|
23
|
+
fails with a compilation error.
|
24
|
+
3. The optional name of an arbitrary
|
25
|
+
[hierarchy level](https://docs.puppetlabs.com/hiera/latest/hierarchy.html) to insert at the
|
26
|
+
top of the hierarchy. This lets you temporarily modify the hierarchy for a single lookup.
|
27
|
+
* If Hiera doesn't find a matching key in the overriding hierarchy level, it continues
|
28
|
+
searching the rest of the hierarchy.
|
29
|
+
|
30
|
+
**Example**: Using `hiera_hash`
|
31
|
+
|
32
|
+
~~~ yaml
|
33
|
+
# Assuming hiera.yaml
|
34
|
+
# :hierarchy:
|
35
|
+
# - web01.example.com
|
36
|
+
# - common
|
37
|
+
|
38
|
+
# Assuming common.yaml:
|
39
|
+
# users:
|
40
|
+
# regular:
|
41
|
+
# 'cdouglas': 'Carrie Douglas'
|
42
|
+
|
43
|
+
# Assuming web01.example.com.yaml:
|
44
|
+
# users:
|
45
|
+
# administrators:
|
46
|
+
# 'aberry': 'Amy Berry'
|
47
|
+
~~~
|
48
|
+
|
49
|
+
~~~ puppet
|
50
|
+
# Assuming we are not web01.example.com:
|
51
|
+
|
52
|
+
$allusers = hiera_hash('users', undef)
|
53
|
+
|
54
|
+
# $allusers contains {regular => {"cdouglas" => "Carrie Douglas"},
|
55
|
+
# administrators => {"aberry" => "Amy Berry"}}
|
56
|
+
~~~
|
57
|
+
|
58
|
+
You can optionally generate the default value with a
|
59
|
+
[lambda](https://docs.puppetlabs.com/puppet/latest/reference/lang_lambdas.html) that
|
60
|
+
takes one parameter.
|
61
|
+
|
62
|
+
**Example**: Using `hiera_hash` with a lambda
|
63
|
+
|
64
|
+
~~~ puppet
|
65
|
+
# Assuming the same Hiera data as the previous example:
|
66
|
+
|
67
|
+
$allusers = hiera_hash('users') | $key | { "Key \'${key}\' not found" }
|
68
|
+
|
69
|
+
# $allusers contains {regular => {"cdouglas" => "Carrie Douglas"},
|
70
|
+
# administrators => {"aberry" => "Amy Berry"}}
|
71
|
+
# If hiera_hash couldn't match its key, it would return the lambda result,
|
72
|
+
# "Key 'users' not found".
|
73
|
+
~~~
|
74
|
+
|
75
|
+
`hiera_hash` expects that all values returned will be hashes. If any of the values
|
76
|
+
found in the data sources are strings or arrays, Puppet raises a type mismatch error.
|
77
|
+
|
78
|
+
See
|
79
|
+
[the documentation](https://docs.puppetlabs.com/hiera/latest/puppet.html#hiera-lookup-functions)
|
80
|
+
for more information about Hiera lookup functions.
|
81
|
+
|
82
|
+
- Since 4.0.0
|
83
|
+
DOC
|
84
|
+
) do |*args|
|
34
85
|
function_fail(["hiera_hash() has been converted to 4x API"])
|
35
86
|
end
|
36
87
|
end
|