puppet 6.29.0 → 7.0.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.
- checksums.yaml +4 -4
- data/CODEOWNERS +16 -2
- data/CONTRIBUTING.md +5 -5
- data/Gemfile +5 -7
- data/Gemfile.lock +52 -143
- data/README.md +5 -5
- data/conf/fileserver.conf +5 -10
- data/ext/README.environment +8 -0
- data/ext/build_defaults.yaml +1 -1
- data/ext/dbfix.sql +132 -0
- data/ext/debian/README.Debian +8 -0
- data/ext/debian/README.source +2 -0
- data/ext/debian/TODO.Debian +1 -0
- data/ext/debian/changelog.erb +1122 -0
- data/ext/debian/compat +1 -0
- data/ext/debian/control +144 -0
- data/ext/debian/copyright +339 -0
- data/ext/debian/docs +1 -0
- data/ext/debian/fileserver.conf +41 -0
- data/ext/debian/puppet-common.dirs +13 -0
- data/ext/debian/puppet-common.install +3 -0
- data/ext/debian/puppet-common.lintian-overrides +5 -0
- data/ext/debian/puppet-common.manpages +28 -0
- data/ext/debian/puppet-common.postinst +35 -0
- data/ext/debian/puppet-common.postrm +33 -0
- data/ext/debian/puppet-el.dirs +1 -0
- data/ext/debian/puppet-el.emacsen-install +25 -0
- data/ext/debian/puppet-el.emacsen-remove +11 -0
- data/ext/debian/puppet-el.emacsen-startup +9 -0
- data/ext/debian/puppet-el.install +1 -0
- data/ext/debian/puppet-testsuite.install +2 -0
- data/ext/debian/puppet-testsuite.lintian-overrides +4 -0
- data/ext/debian/puppet.lintian-overrides +3 -0
- data/ext/debian/puppet.logrotate +20 -0
- data/ext/debian/puppet.postinst +20 -0
- data/ext/debian/puppet.postrm +20 -0
- data/ext/debian/puppet.preinst +20 -0
- data/ext/debian/puppetmaster-common.install +2 -0
- data/ext/debian/puppetmaster-common.manpages +2 -0
- data/ext/debian/puppetmaster-common.postinst +6 -0
- data/ext/debian/puppetmaster-passenger.dirs +4 -0
- data/ext/debian/puppetmaster-passenger.postinst +162 -0
- data/ext/debian/puppetmaster-passenger.postrm +61 -0
- data/ext/debian/puppetmaster.README.debian +17 -0
- data/ext/debian/puppetmaster.default +14 -0
- data/ext/debian/puppetmaster.init +137 -0
- data/ext/debian/puppetmaster.lintian-overrides +3 -0
- data/ext/debian/puppetmaster.postinst +20 -0
- data/ext/debian/puppetmaster.postrm +5 -0
- data/ext/debian/puppetmaster.preinst +22 -0
- data/ext/debian/rules +132 -0
- data/ext/debian/source/format +1 -0
- data/ext/debian/source/options +1 -0
- data/ext/debian/vim-puppet.README.Debian +13 -0
- data/ext/debian/vim-puppet.dirs +5 -0
- data/ext/debian/vim-puppet.yaml +7 -0
- data/ext/debian/watch +2 -0
- data/ext/freebsd/puppetd +26 -0
- data/ext/freebsd/puppetmasterd +26 -0
- data/ext/gentoo/conf.d/puppet +5 -0
- data/ext/gentoo/conf.d/puppetmaster +12 -0
- data/ext/gentoo/init.d/puppet +38 -0
- data/ext/gentoo/init.d/puppetmaster +51 -0
- data/ext/gentoo/puppet/fileserver.conf +41 -0
- data/ext/ips/puppet-agent +44 -0
- data/ext/ips/puppet-master +44 -0
- data/ext/ips/puppet.p5m.erb +12 -0
- data/ext/ips/puppetagent.xml +42 -0
- data/ext/ips/puppetmaster.xml +42 -0
- data/ext/ips/rules +19 -0
- data/ext/ips/transforms +34 -0
- data/ext/ldap/puppet.schema +24 -0
- data/ext/logcheck/puppet +23 -0
- data/{examples → ext}/nagios/check_puppet.rb +2 -2
- data/ext/osx/file_mapping.yaml +28 -0
- data/ext/osx/postflight.erb +109 -0
- data/ext/osx/preflight.erb +52 -0
- data/ext/osx/prototype.plist.erb +38 -0
- data/ext/osx/puppet.plist +0 -2
- data/ext/project_data.yaml +2 -16
- data/ext/redhat/fileserver.conf +41 -0
- data/ext/redhat/logrotate +21 -0
- data/ext/redhat/puppet.spec.erb +841 -0
- data/ext/redhat/server.init +128 -0
- data/ext/redhat/server.sysconfig +13 -0
- data/{examples/enc → ext}/regexp_nodes/classes/databases +0 -0
- data/{examples/enc → ext}/regexp_nodes/classes/webservers +0 -0
- data/{examples/enc → ext}/regexp_nodes/environment/development +0 -0
- data/{examples/enc → ext}/regexp_nodes/parameters/service/prod +0 -0
- data/{examples/enc → ext}/regexp_nodes/parameters/service/qa +0 -0
- data/{examples/enc → ext}/regexp_nodes/parameters/service/sandbox +0 -0
- data/{examples/enc → ext}/regexp_nodes/regexp_nodes.rb +0 -0
- data/ext/solaris/pkginfo +6 -0
- data/ext/solaris/smf/puppetd.xml +77 -0
- data/ext/solaris/smf/puppetmasterd.xml +77 -0
- data/ext/solaris/smf/svc-puppetd +71 -0
- data/ext/solaris/smf/svc-puppetmasterd +67 -0
- data/ext/suse/puppet.spec +310 -0
- data/ext/suse/server.init +173 -0
- data/ext/windows/service/daemon.rb +6 -5
- data/ext/yaml_nodes.rb +105 -0
- data/install.rb +21 -17
- data/lib/puppet/agent.rb +11 -47
- data/lib/puppet/application/agent.rb +16 -18
- data/lib/puppet/application/apply.rb +4 -24
- data/lib/puppet/application/device.rb +100 -106
- data/lib/puppet/application/filebucket.rb +13 -10
- data/lib/puppet/application/lookup.rb +24 -74
- data/lib/puppet/application/resource.rb +16 -32
- data/lib/puppet/application/script.rb +0 -2
- data/lib/puppet/application/ssl.rb +1 -13
- data/lib/puppet/application.rb +178 -108
- data/lib/puppet/application_support.rb +0 -7
- data/lib/puppet/concurrent/thread_local_singleton.rb +3 -6
- data/lib/puppet/configurer/downloader.rb +1 -2
- data/lib/puppet/configurer/plugin_handler.rb +21 -19
- data/lib/puppet/configurer.rb +86 -183
- data/lib/puppet/confine/variable.rb +1 -1
- data/lib/puppet/defaults.rb +130 -244
- data/lib/puppet/environments.rb +82 -146
- data/lib/puppet/face/facts.rb +5 -103
- data/lib/puppet/face/generate.rb +0 -2
- data/lib/puppet/face/help/action.erb +0 -1
- data/lib/puppet/face/help/face.erb +0 -1
- data/lib/puppet/face/help.rb +1 -1
- data/lib/puppet/face/node/clean.rb +0 -11
- data/lib/puppet/face/plugin.rb +5 -8
- data/lib/puppet/ffi/windows/api_types.rb +311 -0
- data/lib/puppet/ffi/windows/constants.rb +404 -0
- data/lib/puppet/ffi/windows/functions.rb +628 -0
- data/lib/puppet/ffi/windows/structs.rb +338 -0
- data/lib/puppet/ffi/windows.rb +12 -0
- data/lib/puppet/file_serving/configuration/parser.rb +3 -34
- data/lib/puppet/file_serving/configuration.rb +0 -8
- data/lib/puppet/file_serving/fileset.rb +2 -14
- data/lib/puppet/file_serving/http_metadata.rb +1 -1
- data/lib/puppet/file_serving/metadata.rb +0 -3
- data/lib/puppet/file_serving/mount/file.rb +4 -4
- data/lib/puppet/file_serving/mount.rb +1 -2
- data/lib/puppet/file_system/file_impl.rb +8 -10
- data/lib/puppet/file_system/jruby.rb +1 -1
- data/lib/puppet/file_system/memory_file.rb +1 -8
- data/lib/puppet/file_system/windows.rb +6 -8
- data/lib/puppet/file_system.rb +1 -1
- data/lib/puppet/forge/repository.rb +0 -1
- data/lib/puppet/forge.rb +4 -4
- data/lib/puppet/functions/all.rb +1 -1
- data/lib/puppet/functions/camelcase.rb +1 -1
- data/lib/puppet/functions/capitalize.rb +2 -2
- data/lib/puppet/functions/downcase.rb +2 -2
- data/lib/puppet/functions/empty.rb +0 -8
- data/lib/puppet/functions/find_template.rb +2 -2
- data/lib/puppet/functions/get.rb +5 -5
- data/lib/puppet/functions/group_by.rb +5 -13
- data/lib/puppet/functions/lest.rb +1 -1
- data/lib/puppet/functions/new.rb +100 -100
- data/lib/puppet/functions/next.rb +1 -18
- data/lib/puppet/functions/partition.rb +4 -12
- data/lib/puppet/functions/require.rb +5 -5
- data/lib/puppet/functions/sort.rb +3 -3
- data/lib/puppet/functions/strftime.rb +0 -1
- data/lib/puppet/functions/tree_each.rb +10 -7
- data/lib/puppet/functions/type.rb +4 -4
- data/lib/puppet/functions/unwrap.rb +2 -17
- data/lib/puppet/functions/upcase.rb +2 -2
- data/lib/puppet/functions/versioncmp.rb +2 -6
- data/lib/puppet/generate/models/type/type.rb +4 -1
- data/lib/puppet/generate/type.rb +0 -9
- data/lib/puppet/http/client.rb +167 -137
- data/lib/puppet/{network/resolver.rb → http/dns.rb} +2 -2
- data/lib/puppet/http/errors.rb +16 -0
- data/lib/puppet/http/external_client.rb +5 -7
- data/lib/puppet/{network/http → http}/factory.rb +8 -15
- data/lib/puppet/{network/http → http}/pool.rb +61 -26
- data/lib/puppet/{network/http/session.rb → http/pool_entry.rb} +2 -3
- data/lib/puppet/http/proxy.rb +137 -0
- data/lib/puppet/http/redirector.rb +4 -17
- data/lib/puppet/http/resolver/server_list.rb +10 -25
- data/lib/puppet/http/resolver/settings.rb +4 -7
- data/lib/puppet/http/resolver/srv.rb +7 -11
- data/lib/puppet/http/resolver.rb +5 -15
- data/lib/puppet/http/response.rb +36 -54
- data/lib/puppet/http/response_converter.rb +24 -0
- data/lib/puppet/http/response_net_http.rb +42 -0
- data/lib/puppet/http/retry_after_handler.rb +4 -13
- data/lib/puppet/http/service/ca.rb +11 -22
- data/lib/puppet/http/service/compiler.rb +23 -144
- data/lib/puppet/http/service/file_server.rb +19 -29
- data/lib/puppet/http/service/puppetserver.rb +26 -12
- data/lib/puppet/http/service/report.rb +8 -10
- data/lib/puppet/http/service.rb +12 -26
- data/lib/puppet/http/session.rb +11 -20
- data/lib/puppet/{network/http → http}/site.rb +1 -2
- data/lib/puppet/http.rb +22 -13
- data/lib/puppet/indirector/catalog/compiler.rb +6 -25
- data/lib/puppet/indirector/catalog/rest.rb +2 -5
- data/lib/puppet/indirector/facts/facter.rb +6 -6
- data/lib/puppet/indirector/facts/rest.rb +3 -22
- data/lib/puppet/indirector/file_bucket_file/rest.rb +3 -9
- data/lib/puppet/indirector/file_content/rest.rb +2 -6
- data/lib/puppet/indirector/file_metadata/rest.rb +3 -10
- data/lib/puppet/indirector/file_server.rb +1 -8
- data/lib/puppet/indirector/generic_http.rb +0 -11
- data/lib/puppet/indirector/indirection.rb +1 -1
- data/lib/puppet/indirector/node/rest.rb +2 -4
- data/lib/puppet/indirector/report/rest.rb +3 -8
- data/lib/puppet/indirector/request.rb +0 -101
- data/lib/puppet/indirector/resource/ral.rb +1 -6
- data/lib/puppet/indirector/rest.rb +12 -263
- data/lib/puppet/indirector/terminus.rb +0 -4
- data/lib/puppet/interface/documentation.rb +0 -1
- data/lib/puppet/module/plan.rb +1 -0
- data/lib/puppet/module/task.rb +1 -1
- data/lib/puppet/module.rb +0 -1
- data/lib/puppet/module_tool/applications/installer.rb +2 -56
- data/lib/puppet/module_tool/applications/uninstaller.rb +1 -1
- data/lib/puppet/module_tool/applications/upgrader.rb +1 -1
- data/lib/puppet/module_tool/applications.rb +0 -1
- data/lib/puppet/module_tool/errors/shared.rb +2 -34
- data/lib/puppet/network/authconfig.rb +2 -96
- data/lib/puppet/network/authorization.rb +13 -35
- data/lib/puppet/network/formats.rb +0 -67
- data/lib/puppet/network/http/api/indirected_routes.rb +3 -21
- data/lib/puppet/network/http/api/master/v3.rb +11 -13
- data/lib/puppet/network/http/connection.rb +247 -316
- data/lib/puppet/network/http/handler.rb +0 -1
- data/lib/puppet/network/http.rb +3 -3
- data/lib/puppet/network/http_pool.rb +16 -34
- data/lib/puppet/node/environment.rb +11 -10
- data/lib/puppet/node.rb +2 -31
- data/lib/puppet/pal/json_catalog_encoder.rb +4 -0
- data/lib/puppet/pal/pal_impl.rb +4 -2
- data/lib/puppet/parser/ast/leaf.rb +2 -3
- data/lib/puppet/parser/ast/pops_bridge.rb +0 -38
- data/lib/puppet/parser/compiler/catalog_validator/relationship_validator.rb +14 -39
- data/lib/puppet/parser/compiler.rb +0 -198
- data/lib/puppet/parser/functions/fqdn_rand.rb +6 -14
- data/lib/puppet/parser/resource.rb +1 -70
- data/lib/puppet/parser/scope.rb +0 -1
- data/lib/puppet/parser/templatewrapper.rb +1 -2
- data/lib/puppet/pops/evaluator/closure.rb +5 -7
- data/lib/puppet/pops/evaluator/deferred_resolver.rb +3 -5
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +0 -5
- data/lib/puppet/pops/evaluator/runtime3_resource_support.rb +3 -4
- data/lib/puppet/pops/evaluator/runtime3_support.rb +1 -1
- data/lib/puppet/pops/issues.rb +0 -5
- data/lib/puppet/pops/loader/ruby_legacy_function_instantiator.rb +6 -8
- data/lib/puppet/pops/lookup/lookup_adapter.rb +2 -3
- data/lib/puppet/pops/model/ast.pp +0 -42
- data/lib/puppet/pops/model/ast.rb +0 -291
- data/lib/puppet/pops/model/ast_transformer.rb +1 -1
- data/lib/puppet/pops/model/factory.rb +1 -47
- data/lib/puppet/pops/model/model_label_provider.rb +0 -5
- data/lib/puppet/pops/model/model_tree_dumper.rb +0 -22
- data/lib/puppet/pops/model/pn_transformer.rb +0 -16
- data/lib/puppet/pops/parser/code_merger.rb +4 -4
- data/lib/puppet/pops/parser/egrammar.ra +0 -58
- data/lib/puppet/pops/parser/eparser.rb +1685 -1896
- data/lib/puppet/pops/parser/lexer2.rb +91 -92
- data/lib/puppet/pops/parser/parser_support.rb +0 -5
- data/lib/puppet/pops/parser/slurp_support.rb +0 -1
- data/lib/puppet/pops/resource/resource_type_impl.rb +2 -24
- data/lib/puppet/pops/serialization/to_stringified_converter.rb +1 -1
- data/lib/puppet/pops/types/p_sem_ver_type.rb +2 -8
- data/lib/puppet/pops/types/p_sensitive_type.rb +0 -10
- data/lib/puppet/pops/types/type_calculator.rb +0 -7
- data/lib/puppet/pops/types/type_formatter.rb +3 -4
- data/lib/puppet/pops/types/type_mismatch_describer.rb +1 -1
- data/lib/puppet/pops/types/type_parser.rb +0 -4
- data/lib/puppet/pops/types/types.rb +1 -2
- data/lib/puppet/pops/validation/checker4_0.rb +9 -37
- data/lib/puppet/pops/validation/tasks_checker.rb +0 -12
- data/lib/puppet/pops/validation/validator_factory_4_0.rb +1 -2
- data/lib/puppet/property/list.rb +1 -1
- data/lib/puppet/provider/aix_object.rb +1 -1
- data/lib/puppet/provider/exec/posix.rb +4 -16
- data/lib/puppet/provider/group/groupadd.rb +10 -18
- data/lib/puppet/provider/nameservice.rb +0 -18
- data/lib/puppet/provider/package/apt.rb +2 -34
- data/lib/puppet/provider/package/aptitude.rb +0 -6
- data/lib/puppet/provider/package/dnfmodule.rb +1 -1
- data/lib/puppet/provider/package/dpkg.rb +0 -10
- data/lib/puppet/provider/package/gem.rb +23 -3
- data/lib/puppet/provider/package/nim.rb +6 -11
- data/lib/puppet/provider/package/pip.rb +3 -16
- data/lib/puppet/provider/package/pkg.rb +2 -23
- data/lib/puppet/provider/package/portage.rb +1 -1
- data/lib/puppet/provider/package/puppet_gem.rb +1 -4
- data/lib/puppet/provider/package/puppetserver_gem.rb +17 -8
- data/lib/puppet/provider/package/windows/exe_package.rb +1 -30
- data/lib/puppet/provider/package/windows/package.rb +1 -2
- data/lib/puppet/provider/package/windows.rb +1 -14
- data/lib/puppet/provider/package/yum.rb +1 -1
- data/lib/puppet/provider/parsedfile.rb +0 -3
- data/lib/puppet/provider/service/base.rb +1 -1
- data/lib/puppet/provider/service/debian.rb +0 -2
- data/lib/puppet/provider/service/init.rb +9 -10
- data/lib/puppet/provider/service/launchd.rb +2 -2
- data/lib/puppet/provider/service/redhat.rb +1 -1
- data/lib/puppet/provider/service/smf.rb +194 -76
- data/lib/puppet/provider/service/systemd.rb +6 -16
- data/lib/puppet/provider/service/upstart.rb +5 -5
- data/lib/puppet/provider/service/windows.rb +0 -38
- data/lib/puppet/provider/user/aix.rb +3 -46
- data/lib/puppet/provider/user/directoryservice.rb +11 -39
- data/lib/puppet/provider/user/useradd.rb +24 -134
- data/lib/puppet/provider.rb +1 -14
- data/lib/puppet/reference/configuration.rb +8 -7
- data/lib/puppet/reference/indirection.rb +1 -1
- data/lib/puppet/reference/providers.rb +2 -2
- data/lib/puppet/resource/catalog.rb +2 -15
- data/lib/puppet/resource/type.rb +3 -119
- data/lib/puppet/resource/type_collection.rb +3 -49
- data/lib/puppet/resource.rb +6 -127
- data/lib/puppet/runtime.rb +2 -13
- data/lib/puppet/settings/environment_conf.rb +0 -1
- data/lib/puppet/settings/integer_setting.rb +17 -0
- data/lib/puppet/settings/port_setting.rb +15 -0
- data/lib/puppet/settings/priority_setting.rb +5 -4
- data/lib/puppet/settings.rb +82 -98
- data/lib/puppet/ssl/base.rb +3 -5
- data/lib/puppet/ssl/certificate.rb +0 -6
- data/lib/puppet/ssl/certificate_request.rb +1 -12
- data/lib/puppet/ssl/certificate_signer.rb +6 -0
- data/lib/puppet/ssl/oids.rb +3 -1
- data/lib/puppet/ssl/ssl_provider.rb +36 -75
- data/lib/puppet/ssl/state_machine.rb +20 -14
- data/lib/puppet/ssl/verifier.rb +2 -6
- data/lib/puppet/ssl.rb +10 -6
- data/lib/puppet/test/test_helper.rb +2 -7
- data/lib/puppet/transaction/additional_resource_generator.rb +1 -1
- data/lib/puppet/transaction/persistence.rb +1 -21
- data/lib/puppet/transaction/report.rb +3 -19
- data/lib/puppet/transaction.rb +1 -7
- data/lib/puppet/type/exec.rb +6 -36
- data/lib/puppet/type/file/checksum.rb +1 -1
- data/lib/puppet/type/file/data_sync.rb +1 -1
- data/lib/puppet/type/file/mode.rb +0 -6
- data/lib/puppet/type/file/selcontext.rb +1 -1
- data/lib/puppet/type/file/source.rb +1 -1
- data/lib/puppet/type/file.rb +12 -32
- data/lib/puppet/type/filebucket.rb +4 -4
- data/lib/puppet/type/group.rb +1 -0
- data/lib/puppet/type/package.rb +8 -16
- data/lib/puppet/type/resources.rb +1 -1
- data/lib/puppet/type/service.rb +41 -26
- data/lib/puppet/type/tidy.rb +3 -22
- data/lib/puppet/type/user.rb +13 -35
- data/lib/puppet/type.rb +1 -77
- data/lib/puppet/util/autoload.rb +8 -1
- data/lib/puppet/util/command_line.rb +1 -1
- data/lib/puppet/util/execution.rb +0 -11
- data/lib/puppet/util/filetype.rb +2 -2
- data/lib/puppet/util/http_proxy.rb +2 -215
- data/lib/puppet/util/json.rb +0 -20
- data/lib/puppet/util/log.rb +4 -8
- data/lib/puppet/util/logging.rb +25 -1
- data/lib/puppet/util/monkey_patches.rb +2 -59
- data/lib/puppet/util/package.rb +16 -25
- data/lib/puppet/util/pidlock.rb +1 -1
- data/lib/puppet/util/posix.rb +5 -54
- data/lib/puppet/util/rdoc/parser/puppet_parser_core.rb +1 -1
- data/lib/puppet/util/rdoc.rb +0 -7
- data/lib/puppet/util/retry_action.rb +1 -1
- data/lib/puppet/util/run_mode.rb +9 -1
- data/lib/puppet/util/selinux.rb +4 -30
- data/lib/puppet/util/suidmanager.rb +2 -1
- data/lib/puppet/util/symbolic_file_mode.rb +17 -29
- data/lib/puppet/util/tagging.rb +0 -1
- data/lib/puppet/util/windows/adsi.rb +0 -46
- data/lib/puppet/util/windows/daemon.rb +360 -0
- data/lib/puppet/util/windows/error.rb +1 -0
- data/lib/puppet/util/windows/eventlog.rb +4 -9
- data/lib/puppet/util/windows/file.rb +8 -242
- data/lib/puppet/util/windows/monkey_patches/process.rb +414 -0
- data/lib/puppet/util/windows/principal.rb +2 -9
- data/lib/puppet/util/windows/process.rb +4 -226
- data/lib/puppet/util/windows/service.rb +11 -457
- data/lib/puppet/util/windows/sid.rb +2 -6
- data/lib/puppet/util/windows/string.rb +12 -13
- data/lib/puppet/util/windows/user.rb +2 -0
- data/lib/puppet/util/windows.rb +3 -11
- data/lib/puppet/util/yaml.rb +1 -42
- data/lib/puppet/util.rb +5 -5
- data/lib/puppet/vendor/require_vendored.rb +0 -1
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet/x509/cert_provider.rb +29 -1
- data/lib/puppet/x509.rb +5 -1
- data/lib/puppet.rb +34 -27
- data/locales/puppet.pot +9633 -5
- data/man/man5/puppet.conf.5 +286 -401
- data/man/man8/puppet-agent.8 +2 -5
- data/man/man8/puppet-apply.8 +2 -2
- data/man/man8/puppet-catalog.8 +9 -9
- data/man/man8/puppet-config.8 +1 -1
- data/man/man8/puppet-describe.8 +1 -1
- data/man/man8/puppet-device.8 +2 -2
- data/man/man8/puppet-doc.8 +1 -1
- data/man/man8/puppet-epp.8 +1 -1
- data/man/man8/puppet-facts.8 +8 -51
- data/man/man8/puppet-filebucket.8 +4 -4
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-lookup.8 +6 -9
- data/man/man8/puppet-module.8 +3 -60
- data/man/man8/puppet-node.8 +5 -5
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +5 -5
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +2 -2
- data/man/man8/puppet-ssl.8 +1 -5
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/ssl/127.0.0.1-key.pem +57 -107
- data/spec/fixtures/ssl/127.0.0.1.pem +31 -52
- data/spec/fixtures/ssl/bad-basic-constraints.pem +35 -57
- data/spec/fixtures/ssl/bad-int-basic-constraints.pem +35 -57
- data/spec/fixtures/ssl/ca.pem +35 -57
- data/spec/fixtures/ssl/crl.pem +18 -28
- data/spec/fixtures/ssl/ec-key.pem +11 -11
- data/spec/fixtures/ssl/ec.pem +24 -33
- data/spec/fixtures/ssl/encrypted-ec-key.pem +12 -12
- data/spec/fixtures/ssl/encrypted-key.pem +58 -108
- data/spec/fixtures/ssl/intermediate-agent-crl.pem +19 -28
- data/spec/fixtures/ssl/intermediate-agent.pem +36 -57
- data/spec/fixtures/ssl/intermediate-crl.pem +21 -31
- data/spec/fixtures/ssl/intermediate.pem +36 -57
- data/spec/fixtures/ssl/pluto-key.pem +57 -107
- data/spec/fixtures/ssl/pluto.pem +30 -52
- data/spec/fixtures/ssl/request-key.pem +57 -107
- data/spec/fixtures/ssl/request.pem +26 -47
- data/spec/fixtures/ssl/revoked-key.pem +57 -107
- data/spec/fixtures/ssl/revoked.pem +30 -52
- data/spec/fixtures/ssl/signed-key.pem +57 -107
- data/spec/fixtures/ssl/signed.pem +30 -52
- data/spec/fixtures/ssl/tampered-cert.pem +30 -52
- data/spec/fixtures/ssl/tampered-csr.pem +26 -47
- data/spec/fixtures/ssl/unknown-127.0.0.1-key.pem +57 -107
- data/spec/fixtures/ssl/unknown-127.0.0.1.pem +29 -50
- data/spec/fixtures/ssl/unknown-ca-key.pem +57 -107
- data/spec/fixtures/ssl/unknown-ca.pem +33 -55
- data/spec/fixtures/unit/forge/bacula.json +1 -1
- data/spec/fixtures/unit/provider/service/smf/{svcs.out → svcs_instances.out} +0 -0
- data/spec/fixtures/unit/provider/user/aix/aix_passwd_file.out +0 -4
- data/spec/integration/application/agent_spec.rb +50 -406
- data/spec/integration/application/apply_spec.rb +1 -20
- data/spec/integration/application/filebucket_spec.rb +16 -32
- data/spec/integration/application/help_spec.rb +2 -0
- data/spec/integration/application/lookup_spec.rb +50 -81
- data/spec/integration/application/module_spec.rb +0 -21
- data/spec/integration/application/plugin_spec.rb +24 -2
- data/spec/integration/configurer_spec.rb +2 -18
- data/spec/integration/defaults_spec.rb +14 -3
- data/spec/integration/environments/settings_interpolation_spec.rb +4 -0
- data/spec/integration/http/client_spec.rb +4 -63
- data/spec/integration/indirector/direct_file_server_spec.rb +3 -1
- data/spec/integration/indirector/facts/facter_spec.rb +39 -93
- data/spec/integration/network/http_pool_spec.rb +3 -21
- data/spec/integration/parser/catalog_spec.rb +0 -38
- data/spec/integration/parser/node_spec.rb +0 -9
- data/spec/integration/parser/pcore_resource_spec.rb +0 -47
- data/spec/integration/resource/type_collection_spec.rb +6 -2
- data/spec/integration/transaction/report_spec.rb +1 -1
- data/spec/integration/transaction_spec.rb +9 -4
- data/spec/integration/type/exec_spec.rb +45 -70
- data/spec/integration/type/file_spec.rb +7 -6
- data/spec/integration/type/package_spec.rb +6 -6
- data/spec/integration/util/rdoc/parser_spec.rb +1 -1
- data/spec/integration/util/windows/adsi_spec.rb +1 -21
- data/spec/integration/util/windows/monkey_patches/process_spec.rb +231 -0
- data/spec/integration/util/windows/principal_spec.rb +0 -21
- data/spec/integration/util/windows/process_spec.rb +9 -1
- data/spec/integration/util/windows/registry_spec.rb +10 -6
- data/spec/integration/util/windows/security_spec.rb +1 -1
- data/spec/lib/matchers/include.rb +27 -0
- data/spec/lib/matchers/include_spec.rb +32 -0
- data/spec/lib/puppet/test_ca.rb +2 -7
- data/spec/lib/puppet_spec/https.rb +1 -1
- data/spec/lib/puppet_spec/modules.rb +2 -13
- data/spec/lib/puppet_spec/puppetserver.rb +3 -55
- data/spec/lib/puppet_spec/settings.rb +1 -1
- data/spec/shared_behaviours/documentation_on_faces.rb +2 -0
- data/spec/spec_helper.rb +17 -13
- data/spec/unit/agent_spec.rb +8 -38
- data/spec/unit/application/agent_spec.rb +19 -33
- data/spec/unit/application/apply_spec.rb +56 -76
- data/spec/unit/application/facts_spec.rb +12 -456
- data/spec/unit/application/filebucket_spec.rb +43 -39
- data/spec/unit/application/lookup_spec.rb +10 -131
- data/spec/unit/application/resource_spec.rb +0 -29
- data/spec/unit/application/ssl_spec.rb +2 -25
- data/spec/unit/application_spec.rb +9 -51
- data/spec/unit/certificate_factory_spec.rb +1 -1
- data/spec/unit/configurer/downloader_spec.rb +6 -8
- data/spec/unit/configurer/plugin_handler_spec.rb +56 -18
- data/spec/unit/configurer_spec.rb +68 -327
- data/spec/unit/confine/feature_spec.rb +1 -1
- data/spec/unit/confine_spec.rb +2 -8
- data/spec/unit/context/trusted_information_spec.rb +2 -6
- data/spec/unit/daemon_spec.rb +11 -2
- data/spec/unit/defaults_spec.rb +68 -55
- data/spec/unit/environments_spec.rb +68 -408
- data/spec/unit/face/generate_spec.rb +0 -64
- data/spec/unit/face/node_spec.rb +11 -0
- data/spec/unit/face/plugin_spec.rb +73 -33
- data/spec/unit/file_bucket/dipper_spec.rb +2 -2
- data/spec/unit/file_bucket/file_spec.rb +1 -1
- data/spec/unit/file_serving/configuration/parser_spec.rb +15 -41
- data/spec/unit/file_serving/configuration_spec.rb +10 -26
- data/spec/unit/file_serving/fileset_spec.rb +0 -60
- data/spec/unit/file_serving/metadata_spec.rb +3 -3
- data/spec/unit/file_serving/terminus_helper_spec.rb +4 -11
- data/spec/unit/file_system_spec.rb +4 -56
- data/spec/unit/forge/module_release_spec.rb +10 -5
- data/spec/unit/functions/assert_type_spec.rb +1 -1
- data/spec/unit/functions/camelcase_spec.rb +1 -1
- data/spec/unit/functions/capitalize_spec.rb +1 -1
- data/spec/unit/functions/downcase_spec.rb +1 -1
- data/spec/unit/functions/empty_spec.rb +0 -10
- data/spec/unit/functions/logging_spec.rb +0 -1
- data/spec/unit/functions/lookup_spec.rb +0 -64
- data/spec/unit/functions/unwrap_spec.rb +0 -8
- data/spec/unit/functions/upcase_spec.rb +1 -1
- data/spec/unit/functions/versioncmp_spec.rb +4 -40
- data/spec/unit/functions4_spec.rb +2 -2
- data/spec/unit/gettext/config_spec.rb +0 -12
- data/spec/unit/http/client_spec.rb +8 -84
- data/spec/unit/{network/resolver_spec.rb → http/dns_spec.rb} +3 -3
- data/spec/unit/http/external_client_spec.rb +4 -4
- data/spec/unit/{network/http → http}/factory_spec.rb +5 -30
- data/spec/unit/{network/http/session_spec.rb → http/pool_entry_spec.rb} +3 -3
- data/spec/unit/{network/http → http}/pool_spec.rb +12 -17
- data/spec/unit/{util/http_proxy_spec.rb → http/proxy_spec.rb} +2 -69
- data/spec/unit/http/resolver_spec.rb +13 -13
- data/spec/unit/http/service/compiler_spec.rb +0 -193
- data/spec/unit/http/service/file_server_spec.rb +3 -3
- data/spec/unit/http/service/puppetserver_spec.rb +34 -4
- data/spec/unit/http/service_spec.rb +0 -1
- data/spec/unit/http/session_spec.rb +16 -14
- data/spec/unit/{network/http → http}/site_spec.rb +3 -3
- data/spec/unit/indirector/catalog/compiler_spec.rb +10 -101
- data/spec/unit/indirector/catalog/rest_spec.rb +0 -8
- data/spec/unit/indirector/face_spec.rb +1 -0
- data/spec/unit/indirector/facts/facter_spec.rb +3 -0
- data/spec/unit/indirector/file_bucket_file/file_spec.rb +5 -3
- data/spec/unit/indirector/file_bucket_file/selector_spec.rb +8 -26
- data/spec/unit/indirector/file_content/rest_spec.rb +0 -4
- data/spec/unit/indirector/file_metadata/rest_spec.rb +0 -4
- data/spec/unit/indirector/file_server_spec.rb +1 -15
- data/spec/unit/indirector/indirection_spec.rb +15 -18
- data/spec/unit/indirector/report/rest_spec.rb +2 -17
- data/spec/unit/indirector/request_spec.rb +0 -264
- data/spec/unit/indirector/resource/ral_spec.rb +75 -40
- data/spec/unit/indirector/rest_spec.rb +98 -752
- data/spec/unit/indirector/store_configs_spec.rb +7 -0
- data/spec/unit/indirector_spec.rb +2 -2
- data/spec/unit/interface/action_spec.rb +9 -0
- data/spec/unit/module_spec.rb +1 -15
- data/spec/unit/module_tool/applications/installer_spec.rb +0 -105
- data/spec/unit/network/authconfig_spec.rb +2 -129
- data/spec/unit/network/authorization_spec.rb +2 -55
- data/spec/unit/network/formats_spec.rb +4 -51
- data/spec/unit/network/http/api/indirected_routes_spec.rb +5 -92
- data/spec/unit/network/http/api/master/v3_spec.rb +28 -7
- data/spec/unit/network/http/api_spec.rb +10 -0
- data/spec/unit/network/http/connection_spec.rb +19 -41
- data/spec/unit/network/http/handler_spec.rb +0 -1
- data/spec/unit/network/http_pool_spec.rb +0 -4
- data/spec/unit/node/environment_spec.rb +33 -21
- data/spec/unit/node_spec.rb +2 -60
- data/spec/unit/parser/compiler_spec.rb +19 -3
- data/spec/unit/parser/functions/create_resources_spec.rb +2 -20
- data/spec/unit/parser/functions/fqdn_rand_spec.rb +1 -15
- data/spec/unit/parser/resource_spec.rb +8 -14
- data/spec/unit/parser/templatewrapper_spec.rb +5 -16
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +4 -7
- data/spec/unit/pops/loaders/loaders_spec.rb +6 -21
- data/spec/unit/pops/parser/parse_application_spec.rb +4 -22
- data/spec/unit/pops/parser/parse_basic_expressions_spec.rb +0 -1
- data/spec/unit/pops/parser/parse_capabilities_spec.rb +8 -21
- data/spec/unit/pops/parser/parse_containers_spec.rb +13 -2
- data/spec/unit/pops/parser/parse_site_spec.rb +20 -24
- data/spec/unit/pops/resource/resource_type_impl_spec.rb +0 -71
- data/spec/unit/pops/serialization/to_from_hr_spec.rb +1 -1
- data/spec/unit/pops/serialization/to_stringified_spec.rb +0 -5
- data/spec/unit/pops/types/p_sem_ver_type_spec.rb +0 -18
- data/spec/unit/pops/types/p_sensitive_type_spec.rb +0 -18
- data/spec/unit/pops/types/type_calculator_spec.rb +6 -12
- data/spec/unit/pops/types/type_factory_spec.rb +1 -1
- data/spec/unit/pops/validator/validator_spec.rb +61 -51
- data/spec/unit/pops/visitor_spec.rb +1 -1
- data/spec/unit/property_spec.rb +0 -1
- data/spec/unit/provider/group/groupadd_spec.rb +2 -5
- data/spec/unit/provider/nameservice_spec.rb +64 -122
- data/spec/unit/provider/package/apt_spec.rb +23 -28
- data/spec/unit/provider/package/aptitude_spec.rb +1 -1
- data/spec/unit/provider/package/base_spec.rb +5 -6
- data/spec/unit/provider/package/dnfmodule_spec.rb +1 -10
- data/spec/unit/provider/package/dpkg_spec.rb +0 -48
- data/spec/unit/provider/package/gem_spec.rb +33 -1
- data/spec/unit/provider/package/nim_spec.rb +0 -42
- data/spec/unit/provider/package/pacman_spec.rb +12 -18
- data/spec/unit/provider/package/pip2_spec.rb +1 -1
- data/spec/unit/provider/package/pip3_spec.rb +1 -1
- data/spec/unit/provider/package/pip_spec.rb +12 -44
- data/spec/unit/provider/package/pkg_spec.rb +4 -29
- data/spec/unit/provider/package/pkgdmg_spec.rb +4 -0
- data/spec/unit/provider/package/puppet_gem_spec.rb +4 -3
- data/spec/unit/provider/package/puppetserver_gem_spec.rb +3 -3
- data/spec/unit/provider/package/windows/exe_package_spec.rb +0 -17
- data/spec/unit/provider/parsedfile_spec.rb +0 -10
- data/spec/unit/provider/service/gentoo_spec.rb +5 -6
- data/spec/unit/provider/service/init_spec.rb +9 -16
- data/spec/unit/provider/service/launchd_spec.rb +0 -11
- data/spec/unit/provider/service/openwrt_spec.rb +29 -23
- data/spec/unit/provider/service/redhat_spec.rb +2 -3
- data/spec/unit/provider/service/smf_spec.rb +401 -165
- data/spec/unit/provider/service/systemd_spec.rb +9 -54
- data/spec/unit/provider/service/windows_spec.rb +0 -203
- data/spec/unit/provider/user/aix_spec.rb +0 -105
- data/spec/unit/provider/user/directoryservice_spec.rb +36 -68
- data/spec/unit/provider/user/hpux_spec.rb +1 -1
- data/spec/unit/provider/user/pw_spec.rb +0 -2
- data/spec/unit/provider/user/useradd_spec.rb +5 -114
- data/spec/unit/provider_spec.rb +12 -22
- data/spec/unit/puppet_spec.rb +4 -12
- data/spec/unit/resource/catalog_spec.rb +2 -15
- data/spec/unit/resource/type_collection_spec.rb +2 -22
- data/spec/unit/resource/type_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +12 -125
- data/spec/unit/settings/http_extra_headers_spec.rb +2 -4
- data/spec/unit/settings/integer_setting_spec.rb +42 -0
- data/spec/unit/settings/port_setting_spec.rb +31 -0
- data/spec/unit/settings/priority_setting_spec.rb +4 -4
- data/spec/unit/settings_spec.rb +79 -110
- data/spec/unit/ssl/base_spec.rb +37 -3
- data/spec/unit/ssl/certificate_request_spec.rb +21 -45
- data/spec/unit/ssl/certificate_spec.rb +2 -11
- data/spec/unit/ssl/ssl_provider_spec.rb +3 -80
- data/spec/unit/ssl/state_machine_spec.rb +5 -21
- data/spec/unit/ssl/verifier_spec.rb +0 -21
- data/spec/unit/transaction/additional_resource_generator_spec.rb +9 -3
- data/spec/unit/transaction/event_manager_spec.rb +11 -14
- data/spec/unit/transaction/persistence_spec.rb +0 -51
- data/spec/unit/transaction/report_spec.rb +0 -2
- data/spec/unit/transaction/resource_harness_spec.rb +2 -2
- data/spec/unit/transaction_spec.rb +55 -96
- data/spec/unit/type/exec_spec.rb +29 -76
- data/spec/unit/type/file/checksum_spec.rb +6 -6
- data/spec/unit/type/file/content_spec.rb +2 -1
- data/spec/unit/type/file/ensure_spec.rb +1 -1
- data/spec/unit/type/file/mode_spec.rb +1 -1
- data/spec/unit/type/file/selinux_spec.rb +5 -3
- data/spec/unit/type/file/source_spec.rb +4 -5
- data/spec/unit/type/file_spec.rb +18 -6
- data/spec/unit/type/group_spec.rb +6 -13
- data/spec/unit/type/package_spec.rb +1 -1
- data/spec/unit/type/resources_spec.rb +7 -7
- data/spec/unit/type/service_spec.rb +189 -87
- data/spec/unit/type/tidy_spec.rb +8 -24
- data/spec/unit/type_spec.rb +24 -4
- data/spec/unit/util/at_fork_spec.rb +2 -2
- data/spec/unit/util/autoload_spec.rb +1 -5
- data/spec/unit/util/backups_spec.rb +2 -3
- data/spec/unit/util/execution_spec.rb +11 -44
- data/spec/unit/util/inifile_spec.rb +14 -6
- data/spec/unit/util/log_spec.rb +7 -8
- data/spec/unit/util/logging_spec.rb +3 -5
- data/spec/unit/util/monkey_patches_spec.rb +0 -6
- data/spec/unit/util/posix_spec.rb +15 -363
- data/spec/unit/util/run_mode_spec.rb +21 -121
- data/spec/unit/util/selinux_spec.rb +68 -163
- data/spec/unit/util/storage_spec.rb +1 -3
- data/spec/unit/util/suidmanager_spec.rb +41 -44
- data/spec/unit/util/windows/sid_spec.rb +0 -41
- data/spec/unit/util/windows/string_spec.rb +1 -3
- data/spec/unit/util/yaml_spec.rb +13 -92
- data/spec/unit/util_spec.rb +6 -31
- data/tasks/generate_cert_fixtures.rake +7 -17
- data/tasks/parallel.rake +3 -3
- metadata +138 -239
- data/conf/auth.conf +0 -150
- data/ext/README.md +0 -13
- data/lib/puppet/application/cert.rb +0 -76
- data/lib/puppet/application/key.rb +0 -4
- data/lib/puppet/application/man.rb +0 -4
- data/lib/puppet/application/status.rb +0 -4
- data/lib/puppet/face/key.rb +0 -16
- data/lib/puppet/face/man.rb +0 -145
- data/lib/puppet/face/module/build.rb +0 -14
- data/lib/puppet/face/module/generate.rb +0 -14
- data/lib/puppet/face/module/search.rb +0 -103
- data/lib/puppet/face/status.rb +0 -51
- data/lib/puppet/facter_impl.rb +0 -96
- data/lib/puppet/ffi/posix/constants.rb +0 -14
- data/lib/puppet/ffi/posix/functions.rb +0 -24
- data/lib/puppet/ffi/posix.rb +0 -10
- data/lib/puppet/file_serving/mount/scripts.rb +0 -24
- data/lib/puppet/indirector/certificate/file.rb +0 -9
- data/lib/puppet/indirector/certificate/rest.rb +0 -18
- data/lib/puppet/indirector/certificate_request/file.rb +0 -9
- data/lib/puppet/indirector/certificate_request/memory.rb +0 -7
- data/lib/puppet/indirector/certificate_request/rest.rb +0 -11
- data/lib/puppet/indirector/file_content/http.rb +0 -22
- data/lib/puppet/indirector/key/file.rb +0 -46
- data/lib/puppet/indirector/key/memory.rb +0 -7
- data/lib/puppet/indirector/ssl_file.rb +0 -162
- data/lib/puppet/indirector/status/local.rb +0 -12
- data/lib/puppet/indirector/status/rest.rb +0 -27
- data/lib/puppet/indirector/status.rb +0 -3
- data/lib/puppet/module_tool/applications/searcher.rb +0 -29
- data/lib/puppet/network/auth_config_parser.rb +0 -90
- data/lib/puppet/network/authstore.rb +0 -283
- data/lib/puppet/network/http/api/master/v3/authorization.rb +0 -18
- data/lib/puppet/network/http/api/master/v3/environment.rb +0 -88
- data/lib/puppet/network/http/base_pool.rb +0 -36
- data/lib/puppet/network/http/compression.rb +0 -127
- data/lib/puppet/network/http/connection_adapter.rb +0 -184
- data/lib/puppet/network/http/nocache_pool.rb +0 -28
- data/lib/puppet/network/rest_controller.rb +0 -2
- data/lib/puppet/network/rights.rb +0 -210
- data/lib/puppet/parser/compiler/catalog_validator/env_relationship_validator.rb +0 -66
- data/lib/puppet/parser/compiler/catalog_validator/site_validator.rb +0 -22
- data/lib/puppet/parser/environment_compiler.rb +0 -202
- data/lib/puppet/pops/types/enumeration.rb +0 -16
- data/lib/puppet/resource/capability_finder.rb +0 -154
- data/lib/puppet/rest/errors.rb +0 -15
- data/lib/puppet/rest/response.rb +0 -35
- data/lib/puppet/rest/route.rb +0 -85
- data/lib/puppet/rest/routes.rb +0 -135
- data/lib/puppet/settings/alias_setting.rb +0 -37
- data/lib/puppet/ssl/host.rb +0 -505
- data/lib/puppet/ssl/key.rb +0 -61
- data/lib/puppet/ssl/validator/default_validator.rb +0 -209
- data/lib/puppet/ssl/validator/no_validator.rb +0 -22
- data/lib/puppet/ssl/validator.rb +0 -61
- data/lib/puppet/ssl/verifier_adapter.rb +0 -58
- data/lib/puppet/status.rb +0 -40
- data/lib/puppet/util/connection.rb +0 -88
- data/lib/puppet/util/fact_dif.rb +0 -81
- data/lib/puppet/util/ssl.rb +0 -83
- data/lib/puppet/util/windows/api_types.rb +0 -309
- data/lib/puppet/util/windows/monkey_patches/dir.rb +0 -40
- data/lib/puppet/vendor/load_pathspec.rb +0 -1
- data/lib/puppet/vendor/pathspec/CHANGELOG.md +0 -2
- data/lib/puppet/vendor/pathspec/LICENSE +0 -201
- data/lib/puppet/vendor/pathspec/PUPPET_README.md +0 -6
- data/lib/puppet/vendor/pathspec/README.md +0 -53
- data/lib/puppet/vendor/pathspec/lib/pathspec/gitignorespec.rb +0 -275
- data/lib/puppet/vendor/pathspec/lib/pathspec/regexspec.rb +0 -17
- data/lib/puppet/vendor/pathspec/lib/pathspec/spec.rb +0 -14
- data/lib/puppet/vendor/pathspec/lib/pathspec.rb +0 -122
- data/man/man8/puppet-key.8 +0 -126
- data/man/man8/puppet-man.8 +0 -76
- data/man/man8/puppet-status.8 +0 -108
- data/spec/fixtures/integration/application/agent/cached_deferred_catalog.json +0 -92
- data/spec/fixtures/integration/application/agent/lib/facter/agent_spec_role.rb +0 -3
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/Gemfile +0 -4
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/Rakefile +0 -3
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/lib/puppet/functions/l10n.rb +0 -8
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/locales/config.yaml +0 -25
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/locales/ja/puppet-l10n.po +0 -19
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/locales/puppet-l10n.pot +0 -20
- data/spec/fixtures/integration/l10n/envs/prod/modules/demo/metadata.json +0 -8
- data/spec/fixtures/ssl/oid-key.pem +0 -117
- data/spec/fixtures/ssl/oid.pem +0 -69
- data/spec/fixtures/ssl/trusted_oid_mapping.yaml +0 -5
- data/spec/fixtures/unit/provider/service/systemd/list_unit_files_services_vendor_preset +0 -9
- data/spec/integration/application/resource_spec.rb +0 -68
- data/spec/integration/application/ssl_spec.rb +0 -20
- data/spec/integration/l10n/compiler_spec.rb +0 -37
- data/spec/integration/network/authconfig_spec.rb +0 -256
- data/spec/integration/util/windows/monkey_patches/dir_spec.rb +0 -11
- data/spec/shared_contexts/l10n.rb +0 -32
- data/spec/unit/application/man_spec.rb +0 -52
- data/spec/unit/capability_spec.rb +0 -414
- data/spec/unit/concurrent/thread_local_singleton_spec.rb +0 -39
- data/spec/unit/face/key_spec.rb +0 -9
- data/spec/unit/face/module/search_spec.rb +0 -231
- data/spec/unit/face/status_spec.rb +0 -9
- data/spec/unit/facter_impl_spec.rb +0 -31
- data/spec/unit/file_serving/mount/scripts_spec.rb +0 -69
- data/spec/unit/indirector/certificate/file_spec.rb +0 -14
- data/spec/unit/indirector/certificate/rest_spec.rb +0 -61
- data/spec/unit/indirector/certificate_request/file_spec.rb +0 -14
- data/spec/unit/indirector/certificate_request/rest_spec.rb +0 -25
- data/spec/unit/indirector/key/file_spec.rb +0 -78
- data/spec/unit/indirector/ssl_file_spec.rb +0 -305
- data/spec/unit/indirector/status/local_spec.rb +0 -10
- data/spec/unit/indirector/status/rest_spec.rb +0 -50
- data/spec/unit/module_tool/applications/searcher_spec.rb +0 -38
- data/spec/unit/network/auth_config_parser_spec.rb +0 -115
- data/spec/unit/network/authstore_spec.rb +0 -407
- data/spec/unit/network/http/api/master/v3/authorization_spec.rb +0 -57
- data/spec/unit/network/http/api/master/v3/environment_spec.rb +0 -185
- data/spec/unit/network/http/compression_spec.rb +0 -240
- data/spec/unit/network/http/nocache_pool_spec.rb +0 -64
- data/spec/unit/network/http_spec.rb +0 -9
- data/spec/unit/network/rights_spec.rb +0 -439
- data/spec/unit/parser/environment_compiler_spec.rb +0 -730
- data/spec/unit/pops/evaluator/deferred_resolver_spec.rb +0 -20
- data/spec/unit/pops/types/enumeration_spec.rb +0 -51
- data/spec/unit/resource/capability_finder_spec.rb +0 -148
- data/spec/unit/rest/route_spec.rb +0 -132
- data/spec/unit/ssl/host_spec.rb +0 -645
- data/spec/unit/ssl/key_spec.rb +0 -173
- data/spec/unit/ssl/validator_spec.rb +0 -278
- data/spec/unit/status_spec.rb +0 -45
- data/spec/unit/util/json_spec.rb +0 -126
- data/spec/unit/util/ssl_spec.rb +0 -91
- data/spec/unit/util/windows_spec.rb +0 -23
@@ -1,202 +0,0 @@
|
|
1
|
-
require 'puppet/parser/compiler'
|
2
|
-
|
3
|
-
# @deprecated application orchestration will be removed in puppet 7
|
4
|
-
class Puppet::Parser::EnvironmentCompiler < Puppet::Parser::Compiler
|
5
|
-
def self.compile(env, code_id=nil)
|
6
|
-
begin
|
7
|
-
env.check_for_reparse
|
8
|
-
|
9
|
-
node = Puppet::Node.new(env)
|
10
|
-
node.environment = env
|
11
|
-
new(node, :code_id => code_id).compile
|
12
|
-
rescue => detail
|
13
|
-
message = _("%{detail} in environment %{env}") % { detail: detail, env: env.name }
|
14
|
-
Puppet.log_exception(detail, message)
|
15
|
-
raise Puppet::Error, message, detail.backtrace
|
16
|
-
end
|
17
|
-
end
|
18
|
-
|
19
|
-
def initialize(node, options = {})
|
20
|
-
super(node, **options)
|
21
|
-
@overridden_functions = {}
|
22
|
-
end
|
23
|
-
|
24
|
-
def add_function_overrides
|
25
|
-
add_function_override('hiera_include', proc { Puppet.debug "Ignoring hiera_include() during environment catalog compilation" })
|
26
|
-
end
|
27
|
-
|
28
|
-
def add_function_override(func_name, override)
|
29
|
-
typed_name = Puppet::Pops::Loader::TypedName.new(:function, func_name)
|
30
|
-
loader = loaders.puppet_system_loader
|
31
|
-
|
32
|
-
# Remove and preserve existing entry. A `nil` is also preserved to indicate
|
33
|
-
# an override that didn't replace a loaded function.
|
34
|
-
entry = loader.get_entry(typed_name)
|
35
|
-
existing = entry.nil? ? nil : entry.value
|
36
|
-
loader.remove_entry(typed_name) unless existing.nil?
|
37
|
-
@overridden_functions[typed_name] = existing
|
38
|
-
|
39
|
-
# Add the override to the loader
|
40
|
-
loader.set_entry(typed_name, override)
|
41
|
-
end
|
42
|
-
|
43
|
-
def remove_function_overrides
|
44
|
-
loader = loaders.puppet_system_loader
|
45
|
-
@overridden_functions.each_pair do |typed_name, overridden|
|
46
|
-
loader.remove_entry(typed_name)
|
47
|
-
loader.set_entry(typed_name, overridden) unless overridden.nil?
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
def add_catalog_validators
|
52
|
-
super
|
53
|
-
add_catalog_validator(CatalogValidator::SiteValidator)
|
54
|
-
add_catalog_validator(CatalogValidator::EnvironmentRelationshipValidator)
|
55
|
-
end
|
56
|
-
|
57
|
-
def compile
|
58
|
-
Puppet.deprecation_warning("Application orchestration is deprecated. See https://puppet.com/docs/puppet/5.5/deprecated_language.html")
|
59
|
-
|
60
|
-
add_function_overrides
|
61
|
-
begin
|
62
|
-
Puppet.override(@context_overrides, _("For compiling environment catalog %{env}") % { env: environment.name }) do
|
63
|
-
@catalog.environment_instance = environment
|
64
|
-
|
65
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Created settings scope"), [:compiler, :create_settings_scope]) { create_settings_scope }
|
66
|
-
|
67
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Evaluated main"), [:compiler, :evaluate_main]) { evaluate_main }
|
68
|
-
|
69
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Evaluated site"), [:compiler, :evaluate_site]) { evaluate_site }
|
70
|
-
|
71
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Evaluated application instances"), [:compiler, :evaluate_applications]) { evaluate_applications }
|
72
|
-
|
73
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Prune"), [:compiler, :prune_catalog]) { prune_catalog }
|
74
|
-
|
75
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Validate Catalog pre-finish"), [:compiler, :validate_pre_finish]) do
|
76
|
-
validate_catalog(CatalogValidator::PRE_FINISH)
|
77
|
-
end
|
78
|
-
|
79
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Finished catalog"), [:compiler, :finish_catalog]) { finish }
|
80
|
-
|
81
|
-
fail_on_unevaluated
|
82
|
-
|
83
|
-
Puppet::Util::Profiler.profile(_("Env Compile: Validate Catalog final"), [:compiler, :validate_final]) do
|
84
|
-
validate_catalog(CatalogValidator::FINAL)
|
85
|
-
end
|
86
|
-
|
87
|
-
if block_given?
|
88
|
-
yield @catalog
|
89
|
-
else
|
90
|
-
@catalog
|
91
|
-
end
|
92
|
-
end
|
93
|
-
ensure
|
94
|
-
remove_function_overrides
|
95
|
-
end
|
96
|
-
end
|
97
|
-
|
98
|
-
# @api private
|
99
|
-
def prune_catalog
|
100
|
-
prune_env_catalog
|
101
|
-
end
|
102
|
-
|
103
|
-
# Prunes the catalog by dropping all resources that are not contained under the Site (if a site expression is used).
|
104
|
-
# As a consequence all edges to/from dropped resources are also dropped.
|
105
|
-
# Once the pruning is performed, this compiler returns the pruned list when calling the #resources method.
|
106
|
-
# The pruning does not alter the order of resources in the resources list.
|
107
|
-
#
|
108
|
-
def prune_env_catalog
|
109
|
-
# Everything under Class[main], that is not under (inclusive of) Site[site] should be pruned as those resources
|
110
|
-
# are intended for nodes in a node catalog.
|
111
|
-
#
|
112
|
-
the_main_class_resource = @catalog.resource('Class', '')
|
113
|
-
the_site_resource = @catalog.resource('Site', 'site')
|
114
|
-
|
115
|
-
# Get downstream vertexes returns a hash where the keys are the resources and values nesting level
|
116
|
-
rooted_in_main = @catalog.downstream_from_vertex(the_main_class_resource).keys
|
117
|
-
|
118
|
-
to_be_removed =
|
119
|
-
if the_site_resource
|
120
|
-
keep_from_site = @catalog.downstream_from_vertex(the_site_resource).keys
|
121
|
-
keep_from_site << the_site_resource
|
122
|
-
rooted_in_main - keep_from_site
|
123
|
-
else
|
124
|
-
rooted_in_main
|
125
|
-
end
|
126
|
-
|
127
|
-
@catalog.remove_resource(*to_be_removed)
|
128
|
-
# The compiler keeps a list of added resources, this shadows that list with the now pruned result
|
129
|
-
@pruned_resources = @catalog.resources
|
130
|
-
end
|
131
|
-
|
132
|
-
def add_resource(scope, resource)
|
133
|
-
@resources << resource
|
134
|
-
@catalog.add_resource(resource)
|
135
|
-
|
136
|
-
if !resource.class? && resource[:stage]
|
137
|
-
raise ArgumentError, _("Only classes can set 'stage'; normal resources like %{resource} cannot change run stage") % { resource: resource }
|
138
|
-
end
|
139
|
-
|
140
|
-
# Stages should not be inside of classes. They are always a
|
141
|
-
# top-level container, regardless of where they appear in the
|
142
|
-
# manifest.
|
143
|
-
return if resource.stage?
|
144
|
-
|
145
|
-
# This adds a resource to the class it lexically appears in in the
|
146
|
-
# manifest.
|
147
|
-
unless resource.class?
|
148
|
-
@catalog.add_edge(scope.resource, resource)
|
149
|
-
end
|
150
|
-
resource.mark_unevaluated_consumer if is_capability_consumer?(resource)
|
151
|
-
assert_app_in_site(scope, resource)
|
152
|
-
end
|
153
|
-
|
154
|
-
def evaluate_ast_node()
|
155
|
-
# Do nothing, the environment catalog is not built for a particular node.
|
156
|
-
end
|
157
|
-
|
158
|
-
def on_empty_site
|
159
|
-
Puppet.warning(_("Environment Compiler: Could not find a site definition to evaluate"))
|
160
|
-
end
|
161
|
-
|
162
|
-
def evaluate_applications
|
163
|
-
exceptwrap do
|
164
|
-
resources.select { |resource| type = resource.resource_type; type.is_a?(Puppet::Resource::Type) && type.application? }.each do |resource|
|
165
|
-
Puppet::Util::Profiler.profile(_("Evaluated application %{resource}") % { resource: resource }, [:compiler, :evaluate_resource, resource]) do
|
166
|
-
resource.evaluate
|
167
|
-
end
|
168
|
-
end
|
169
|
-
end
|
170
|
-
end
|
171
|
-
|
172
|
-
def evaluate_classes(titles, scope, lazy)
|
173
|
-
# Always lazy in an Environment compilation
|
174
|
-
super(titles, scope, true)
|
175
|
-
end
|
176
|
-
|
177
|
-
# Overrides the regular compiler to be able to return the list of resources after a prune
|
178
|
-
# has taken place in the graph representation. Before a prune, the list is the same as in the regular
|
179
|
-
# compiler
|
180
|
-
#
|
181
|
-
def resources
|
182
|
-
@pruned_resources || super
|
183
|
-
end
|
184
|
-
|
185
|
-
def is_capability?(value)
|
186
|
-
if value.is_a?(Array)
|
187
|
-
value.find { |ev| is_capability?(ev) }
|
188
|
-
elsif value.is_a?(Puppet::Resource)
|
189
|
-
rstype = value.resource_type
|
190
|
-
rstype.nil? ? false : rstype.is_capability?
|
191
|
-
else
|
192
|
-
false
|
193
|
-
end
|
194
|
-
end
|
195
|
-
private :is_capability?
|
196
|
-
|
197
|
-
def is_capability_consumer?(resource)
|
198
|
-
resource.eachparam { |param| return true if (param.name == :consume || param.name == :require) && is_capability?(param.value) }
|
199
|
-
false
|
200
|
-
end
|
201
|
-
private :is_capability_consumer?
|
202
|
-
end
|
@@ -1,16 +0,0 @@
|
|
1
|
-
# The Enumeration class provides default Enumerable::Enumerator creation for Puppet Programming Language
|
2
|
-
# runtime objects that supports the concept of enumeration.
|
3
|
-
#
|
4
|
-
module Puppet::Pops::Types
|
5
|
-
class Enumeration
|
6
|
-
def self.enumerator(o)
|
7
|
-
Puppet.deprecation_warning(_('Enumeration.enumerator is deprecated. Use Iterable.on instead'))
|
8
|
-
Iterable.on(o)
|
9
|
-
end
|
10
|
-
|
11
|
-
def enumerator(o)
|
12
|
-
Puppet.deprecation_warning(_('Enumeration.enumerator is deprecated. Use Iterable.on instead'))
|
13
|
-
Iterable.on(o)
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
@@ -1,154 +0,0 @@
|
|
1
|
-
#
|
2
|
-
# A helper module to look a capability up from PuppetDB
|
3
|
-
#
|
4
|
-
# @todo lutter 2015-03-10: determine whether this should be based on
|
5
|
-
# Puppet::Pops::Evaluator::Collectors, or at least use
|
6
|
-
# Puppet::Util::Puppetdb::Http
|
7
|
-
|
8
|
-
require 'net/http'
|
9
|
-
require 'cgi'
|
10
|
-
require 'puppet/util/json'
|
11
|
-
|
12
|
-
# @api private
|
13
|
-
module Puppet::Resource::CapabilityFinder
|
14
|
-
|
15
|
-
# Looks up a capability resource from PuppetDB. Capability resources are
|
16
|
-
# required to be unique per environment and code id. If multiple copies of a
|
17
|
-
# capability resource are found, the one matching the current code id is
|
18
|
-
# used.
|
19
|
-
#
|
20
|
-
# @param environment [String] environment name
|
21
|
-
# @param code_id [String,nil] code_id of the catalog
|
22
|
-
# @param cap [Puppet::Resource] the capability resource type instance
|
23
|
-
# @return [Puppet::Resource,nil] The found capability resource or `nil` if it could not be found
|
24
|
-
def self.find(environment, code_id, cap)
|
25
|
-
unless Puppet::Util.const_defined?('Puppetdb')
|
26
|
-
#TRANSLATOR PuppetDB is a product name and should not be translated
|
27
|
-
raise Puppet::DevError, _('PuppetDB is not available')
|
28
|
-
end
|
29
|
-
|
30
|
-
resources = search(nil, nil, cap)
|
31
|
-
|
32
|
-
if resources.size > 1
|
33
|
-
Puppet.debug "Found multiple resources when looking up capability #{cap}, filtering by environment #{environment}"
|
34
|
-
resources = resources.select { |r| r['tags'].any? { |t| t == "producer:#{environment}" } }
|
35
|
-
end
|
36
|
-
|
37
|
-
if resources.empty?
|
38
|
-
Puppet.debug "Could not find capability resource #{cap} in PuppetDB"
|
39
|
-
elsif resources.size == 1
|
40
|
-
resource_hash = resources.first
|
41
|
-
else
|
42
|
-
code_id_resource = disambiguate_by_code_id(environment, code_id, cap)
|
43
|
-
if code_id_resource
|
44
|
-
resource_hash = code_id_resource
|
45
|
-
else
|
46
|
-
#TRANSLATOR PuppetDB is a product name and should not be translated
|
47
|
-
message = _("Unexpected response from PuppetDB when looking up %{capability}:") % { capability: cap }
|
48
|
-
message += "\n" + _("expected exactly one resource but got %{count};") % { count: resources.size }
|
49
|
-
message += "\n" + _("returned data is:\n%{resources}") % { resources: resources.inspect }
|
50
|
-
raise Puppet::DevError, message
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
if resource_hash
|
55
|
-
resource_hash['type'] = cap.resource_type
|
56
|
-
instantiate_resource(resource_hash)
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
def self.search(environment, code_id, cap)
|
61
|
-
query_terms = [
|
62
|
-
'and',
|
63
|
-
['=', 'type', cap.type.capitalize],
|
64
|
-
['=', 'title', cap.title.to_s],
|
65
|
-
]
|
66
|
-
|
67
|
-
if environment.nil?
|
68
|
-
query_terms << ['~', 'tag', "^producer:"]
|
69
|
-
else
|
70
|
-
query_terms << ['=', 'tag', "producer:#{environment}"]
|
71
|
-
end
|
72
|
-
|
73
|
-
unless code_id.nil?
|
74
|
-
query_terms << ['in', 'certname',
|
75
|
-
['extract', 'certname',
|
76
|
-
['select_catalogs',
|
77
|
-
['=', 'code_id', code_id]]]]
|
78
|
-
end
|
79
|
-
|
80
|
-
#TRANSLATOR PuppetDB is a product name and should not be translated
|
81
|
-
Puppet.notice _("Looking up capability %{capability} in PuppetDB: %{query_terms}") % { capability: cap, query_terms: query_terms }
|
82
|
-
|
83
|
-
query_puppetdb(query_terms)
|
84
|
-
end
|
85
|
-
|
86
|
-
def self.query_puppetdb(query)
|
87
|
-
begin
|
88
|
-
# If using PuppetDB >= 4, use the API method query_puppetdb()
|
89
|
-
result = if Puppet::Util::Puppetdb.respond_to?(:query_puppetdb)
|
90
|
-
# PuppetDB 4 uses a unified query endpoint, so we have to specify what we're querying
|
91
|
-
Puppet::Util::Puppetdb.query_puppetdb(["from", "resources", query])
|
92
|
-
# For PuppetDB < 4, use the old internal method action()
|
93
|
-
else
|
94
|
-
url = "/pdb/query/v4/resource?query=#{Puppet::Util.uri_query_encode(query.to_json)}"
|
95
|
-
response = Puppet::Util::Puppetdb::Http.action(url) do |conn, uri|
|
96
|
-
conn.get(uri, { 'Accept' => 'application/json'})
|
97
|
-
end
|
98
|
-
Puppet::Util::Json.load(response.body)
|
99
|
-
end
|
100
|
-
|
101
|
-
# The format of the response body is documented at
|
102
|
-
# https://puppet.com/docs/puppetdb/3.0/api/query/v4/resources.html#response-format
|
103
|
-
unless result.is_a?(Array)
|
104
|
-
#TRANSLATOR PuppetDB is a product name and should not be translated
|
105
|
-
raise Puppet::DevError, _("Unexpected response from PuppetDB when looking up %{capability}: expected an Array but got %{result}") %
|
106
|
-
{ capability: cap, result: result.inspect }
|
107
|
-
end
|
108
|
-
|
109
|
-
result
|
110
|
-
rescue Puppet::Util::Json::ParseError => e
|
111
|
-
#TRANSLATOR PuppetDB is a product name and should not be translated
|
112
|
-
raise Puppet::DevError, _("Invalid JSON from PuppetDB when looking up %{capability}\n%{detail}") % { capability: cap, detail: e }
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
|
-
# Find a distinct copy of the given capability resource by searching for only
|
117
|
-
# resources matching the given code_id. Returns `nil` if no code_id is
|
118
|
-
# supplied or if there isn't exactly one matching resource.
|
119
|
-
#
|
120
|
-
# @param environment [String] environment name
|
121
|
-
# @param code_id [String,nil] code_id of the catalog
|
122
|
-
# @param cap [Puppet::Resource] the capability resource type instance
|
123
|
-
def self.disambiguate_by_code_id(environment, code_id, cap)
|
124
|
-
if code_id
|
125
|
-
Puppet.debug "Found multiple resources when looking up capability #{cap}, filtering by code id #{code_id}"
|
126
|
-
resources = search(environment, code_id, cap)
|
127
|
-
|
128
|
-
if resources.size > 1
|
129
|
-
Puppet.debug "Found multiple resources matching code id #{code_id} when looking up #{cap}"
|
130
|
-
nil
|
131
|
-
else
|
132
|
-
resources.first
|
133
|
-
end
|
134
|
-
end
|
135
|
-
end
|
136
|
-
private_class_method :disambiguate_by_code_id
|
137
|
-
|
138
|
-
def self.instantiate_resource(resource_hash)
|
139
|
-
real_type = resource_hash['type']
|
140
|
-
resource = Puppet::Resource.new(real_type, resource_hash['title'])
|
141
|
-
real_type.parameters.each do |param|
|
142
|
-
param = param.to_s
|
143
|
-
next if param == 'name'
|
144
|
-
value = resource_hash['parameters'][param]
|
145
|
-
if value
|
146
|
-
resource[param] = value
|
147
|
-
else
|
148
|
-
Puppet.debug "No capability value for #{resource}->#{param}"
|
149
|
-
end
|
150
|
-
end
|
151
|
-
return resource
|
152
|
-
end
|
153
|
-
private_class_method :instantiate_resource
|
154
|
-
end
|
data/lib/puppet/rest/errors.rb
DELETED
@@ -1,15 +0,0 @@
|
|
1
|
-
# @deprecated Use {Puppet::HTTP::Client} instead.
|
2
|
-
module Puppet::Rest
|
3
|
-
class ResponseError < Puppet::Error
|
4
|
-
attr_reader :response
|
5
|
-
|
6
|
-
# Error thrown when request status is not OK.
|
7
|
-
# @param [String] msg the error message
|
8
|
-
# @param [Puppet::Rest::Response] response the response from the failed
|
9
|
-
# request
|
10
|
-
def initialize(msg, response = nil)
|
11
|
-
super(msg)
|
12
|
-
@response = response
|
13
|
-
end
|
14
|
-
end
|
15
|
-
end
|
data/lib/puppet/rest/response.rb
DELETED
@@ -1,35 +0,0 @@
|
|
1
|
-
# @deprecated Use {Puppet::HTTP::Client} instead.
|
2
|
-
module Puppet::Rest
|
3
|
-
# This is a wrapper for the HTTP::Message class of the HTTPClient
|
4
|
-
# gem. It is designed to wrap a message sent as an HTTP response.
|
5
|
-
class Response
|
6
|
-
def initialize(message)
|
7
|
-
@message = message
|
8
|
-
end
|
9
|
-
|
10
|
-
def body
|
11
|
-
@message.body
|
12
|
-
end
|
13
|
-
|
14
|
-
def content_type
|
15
|
-
@message.content_type
|
16
|
-
end
|
17
|
-
|
18
|
-
def content_encoding
|
19
|
-
@message.headers['Content-Encoding']
|
20
|
-
end
|
21
|
-
|
22
|
-
def status_code
|
23
|
-
@message.status
|
24
|
-
end
|
25
|
-
|
26
|
-
def ok?
|
27
|
-
@message.ok?
|
28
|
-
end
|
29
|
-
|
30
|
-
def to_exception
|
31
|
-
message = _("Error %{code} on SERVER: %{returned_message}") % { code: status_code, returned_message: body }
|
32
|
-
Puppet::Rest::ResponseError.new(message, self)
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
data/lib/puppet/rest/route.rb
DELETED
@@ -1,85 +0,0 @@
|
|
1
|
-
require 'uri'
|
2
|
-
require 'puppet/util/connection'
|
3
|
-
|
4
|
-
# @deprecated Use {Puppet::HTTP::Client} instead.
|
5
|
-
module Puppet::Rest
|
6
|
-
class Route
|
7
|
-
attr_reader :server
|
8
|
-
|
9
|
-
# Create a Route containing information for querying the given API,
|
10
|
-
# hosted at a server determined either by SRV service or by the
|
11
|
-
# fallback server on the fallback port.
|
12
|
-
# @param [String] api the path leading to the root of the API. Must
|
13
|
-
# contain a trailing slash for proper endpoint path
|
14
|
-
# construction
|
15
|
-
# @param [Symbol] server_setting the setting to check for special
|
16
|
-
# server configuration
|
17
|
-
# @param [Symbol] port_setting the setting to check for special
|
18
|
-
# port configuration
|
19
|
-
# @param [Symbol] srv_service the name of the service when using SRV
|
20
|
-
# records
|
21
|
-
def initialize(api:, server_setting: :server, port_setting: :serverport, srv_service: :puppet)
|
22
|
-
@api = api
|
23
|
-
@default_server = Puppet::Util::Connection.determine_server(server_setting)
|
24
|
-
@default_port = Puppet::Util::Connection.determine_port(port_setting, server_setting)
|
25
|
-
@srv_service = srv_service
|
26
|
-
end
|
27
|
-
|
28
|
-
# Select a server and port to create a base URL for the API specified by this
|
29
|
-
# route. If the connection fails and SRV records are in use, the next suitable
|
30
|
-
# server will be tried. If SRV records are not in use or no successful connection
|
31
|
-
# could be made, fall back to the configured server and port for this API, taking
|
32
|
-
# into account failover settings.
|
33
|
-
# @parma [Puppet::Network::Resolver] dns_resolver the DNS resolver to use to check
|
34
|
-
# SRV records
|
35
|
-
# @yield [URI] supply a base URL to make a request with
|
36
|
-
# @raise [Puppet::Error] if connection to selected server and port fails, and SRV
|
37
|
-
# records are not in use
|
38
|
-
def with_base_url(dns_resolver)
|
39
|
-
if @server && @port
|
40
|
-
# First try connecting to the previously selected server and port.
|
41
|
-
begin
|
42
|
-
return yield(base_url)
|
43
|
-
rescue SystemCallError => e
|
44
|
-
if Puppet[:use_srv_records]
|
45
|
-
Puppet.debug "Connection to cached server and port #{@server}:#{@port} failed, reselecting."
|
46
|
-
else
|
47
|
-
raise Puppet::Error, _("Connection to cached server and port %{server}:%{port} failed: %{message}") %
|
48
|
-
{ server: @server, port: @port, message: e.message }
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
|
53
|
-
if Puppet[:use_srv_records]
|
54
|
-
dns_resolver.each_srv_record(Puppet[:srv_domain], @srv_service) do |srv_server, srv_port|
|
55
|
-
# Try each of the servers for this service in weighted order
|
56
|
-
# until a working one is found.
|
57
|
-
begin
|
58
|
-
@server = srv_server
|
59
|
-
@port = srv_port
|
60
|
-
return yield(base_url)
|
61
|
-
rescue SystemCallError
|
62
|
-
Puppet.debug "Connection to selected server and port #{@server}:#{@port} failed. Trying next cached SRV record."
|
63
|
-
@server = nil
|
64
|
-
@port = nil
|
65
|
-
end
|
66
|
-
end
|
67
|
-
end
|
68
|
-
|
69
|
-
# If not using SRV records, fall back to the defaults calculated above
|
70
|
-
@server = @default_server
|
71
|
-
@port = @default_port
|
72
|
-
|
73
|
-
Puppet.debug "No more servers in SRV record, falling back to #{@server}:#{@port}" if Puppet[:use_srv_records]
|
74
|
-
return yield(base_url)
|
75
|
-
end
|
76
|
-
|
77
|
-
private
|
78
|
-
|
79
|
-
# Returns a URI built from the information stored by this route,
|
80
|
-
# e.g. 'https://myserver.com:555/myapi/v1/'
|
81
|
-
def base_url
|
82
|
-
URI::HTTPS.build(host: @server, port: @port, path: @api)
|
83
|
-
end
|
84
|
-
end
|
85
|
-
end
|
data/lib/puppet/rest/routes.rb
DELETED
@@ -1,135 +0,0 @@
|
|
1
|
-
require 'time'
|
2
|
-
require 'puppet/rest/route'
|
3
|
-
require 'puppet/network/http_pool'
|
4
|
-
require 'puppet/network/http/compression'
|
5
|
-
|
6
|
-
# @deprecated Use {Puppet::HTTP::Client} instead.
|
7
|
-
module Puppet::Rest
|
8
|
-
module Routes
|
9
|
-
extend Puppet::Network::HTTP::Compression.module
|
10
|
-
|
11
|
-
ACCEPT_ENCODING = 'gzip;q=1.0,deflate;q=0.6,identity;q=0.3'
|
12
|
-
|
13
|
-
def self.ca
|
14
|
-
Puppet.deprecation_warning("Puppet::Rest::Routes is deprecated, use Puppet::HTTP::Client instead")
|
15
|
-
|
16
|
-
@ca ||= Route.new(api: '/puppet-ca/v1/',
|
17
|
-
server_setting: :ca_server,
|
18
|
-
port_setting: :ca_port,
|
19
|
-
srv_service: :ca)
|
20
|
-
end
|
21
|
-
|
22
|
-
def self.clear
|
23
|
-
@ca = nil
|
24
|
-
end
|
25
|
-
|
26
|
-
# Make an HTTP request to fetch the named certificate.
|
27
|
-
#
|
28
|
-
# @param name [String] the name of the certificate to fetch
|
29
|
-
# @param ssl_context [Puppet::SSL::SSLContext] the ssl content to use when making the request
|
30
|
-
# @raise [Puppet::Rest::ResponseError] if the response status is not OK
|
31
|
-
# @return [String] the PEM-encoded certificate or certificate bundle
|
32
|
-
def self.get_certificate(name, ssl_context)
|
33
|
-
ca.with_base_url(Puppet::Network::Resolver.new) do |url|
|
34
|
-
header = { 'Accept' => 'text/plain', 'Accept-Encoding' => ACCEPT_ENCODING }
|
35
|
-
url.path += "certificate/#{name}"
|
36
|
-
|
37
|
-
use_ssl = url.is_a? URI::HTTPS
|
38
|
-
|
39
|
-
client = Puppet::Network::HttpPool.connection(url.host, url.port, use_ssl: use_ssl, ssl_context: ssl_context)
|
40
|
-
|
41
|
-
response = client.get(url.request_uri, header)
|
42
|
-
unless response.code.to_i == 200
|
43
|
-
raise Puppet::Rest::ResponseError.new(response.message, response)
|
44
|
-
end
|
45
|
-
|
46
|
-
Puppet.info _("Downloaded certificate for %{name} from %{server}") % { name: name, server: ca.server }
|
47
|
-
|
48
|
-
uncompress_body(response)
|
49
|
-
end
|
50
|
-
end
|
51
|
-
|
52
|
-
# Make an HTTP request to fetch the named crl.
|
53
|
-
#
|
54
|
-
# @param name [String] name of the crl to fetch
|
55
|
-
# @param ssl_context [Puppet::SSL::SSLContext] the ssl content to use when making the request
|
56
|
-
# @param if_modified_since [Time, nil] If non-nil, then only download the CRL if it has been
|
57
|
-
# modified since the specified time.
|
58
|
-
# @raise [Puppet::Rest::ResponseError] if the response status is not OK
|
59
|
-
# @return [String] the PEM-encoded crl
|
60
|
-
def self.get_crls(name, ssl_context, if_modified_since: nil)
|
61
|
-
ca.with_base_url(Puppet::Network::Resolver.new) do |url|
|
62
|
-
header = { 'Accept' => 'text/plain', 'Accept-Encoding' => ACCEPT_ENCODING }
|
63
|
-
header['If-Modified-Since'] = if_modified_since.httpdate if if_modified_since
|
64
|
-
|
65
|
-
url.path += "certificate_revocation_list/#{name}"
|
66
|
-
|
67
|
-
use_ssl = url.is_a? URI::HTTPS
|
68
|
-
|
69
|
-
client = Puppet::Network::HttpPool.connection(url.host, url.port, use_ssl: use_ssl, ssl_context: ssl_context)
|
70
|
-
|
71
|
-
response = client.get(url.request_uri, header)
|
72
|
-
unless response.code.to_i == 200
|
73
|
-
raise Puppet::Rest::ResponseError.new(response.message, response)
|
74
|
-
end
|
75
|
-
|
76
|
-
Puppet.info _("Downloaded certificate revocation list for %{name} from %{server}") % { name: name, server: ca.server }
|
77
|
-
|
78
|
-
uncompress_body(response)
|
79
|
-
end
|
80
|
-
end
|
81
|
-
|
82
|
-
# Make an HTTP request to send the named CSR.
|
83
|
-
#
|
84
|
-
# @param csr_pem [String] the contents of the CSR to sent to the CA
|
85
|
-
# @param name [String] the name of the host whose CSR is being submitted
|
86
|
-
# @param ssl_context [Puppet::SSL::SSLContext] the ssl content to use when making the request
|
87
|
-
# @raise [Puppet::Rest::ResponseError] if the response status is not OK
|
88
|
-
def self.put_certificate_request(csr_pem, name, ssl_context)
|
89
|
-
ca.with_base_url(Puppet::Network::Resolver.new) do |url|
|
90
|
-
header = { 'Accept' => 'text/plain',
|
91
|
-
'Accept-Encoding' => ACCEPT_ENCODING,
|
92
|
-
'Content-Type' => 'text/plain' }
|
93
|
-
url.path += "certificate_request/#{name}"
|
94
|
-
|
95
|
-
use_ssl = url.is_a? URI::HTTPS
|
96
|
-
|
97
|
-
client = Puppet::Network::HttpPool.connection(url.host, url.port, use_ssl: use_ssl, ssl_context: ssl_context)
|
98
|
-
|
99
|
-
response = client.put(url.request_uri, csr_pem, header)
|
100
|
-
if response.code.to_i == 200
|
101
|
-
Puppet.debug "Submitted certificate request to server."
|
102
|
-
else
|
103
|
-
raise Puppet::Rest::ResponseError.new(response.message, response)
|
104
|
-
end
|
105
|
-
end
|
106
|
-
end
|
107
|
-
|
108
|
-
# Make an HTTP request to get the named CSR.
|
109
|
-
#
|
110
|
-
# @param name [String] the name of the host whose CSR is being queried
|
111
|
-
# @param ssl_context [Puppet::SSL::SSLContext] the ssl content to use when making the request
|
112
|
-
# @raise [Puppet::Rest::ResponseError] if the response status is not OK
|
113
|
-
# @return [String] the PEM encoded certificate request
|
114
|
-
# @deprecated
|
115
|
-
def self.get_certificate_request(name, ssl_context)
|
116
|
-
ca.with_base_url(Puppet::Network::Resolver.new) do |url|
|
117
|
-
header = { 'Accept' => 'text/plain', 'Accept-Encoding' => ACCEPT_ENCODING }
|
118
|
-
url.path += "certificate_request/#{name}"
|
119
|
-
|
120
|
-
use_ssl = url.is_a? URI::HTTPS
|
121
|
-
|
122
|
-
client = Puppet::Network::HttpPool.connection(url.host, url.port, use_ssl: use_ssl, ssl_context: ssl_context)
|
123
|
-
|
124
|
-
response = client.get(url.request_uri, header)
|
125
|
-
unless response.code.to_i == 200
|
126
|
-
raise Puppet::Rest::ResponseError.new(response.message, response)
|
127
|
-
end
|
128
|
-
|
129
|
-
Puppet.debug _("Downloaded existing certificate request for %{name} from %{server}") % { name: name, server: ca.server }
|
130
|
-
|
131
|
-
uncompress_body(response)
|
132
|
-
end
|
133
|
-
end
|
134
|
-
end
|
135
|
-
end
|
@@ -1,37 +0,0 @@
|
|
1
|
-
class Puppet::Settings::AliasSetting
|
2
|
-
attr_reader :name, :alias_name
|
3
|
-
|
4
|
-
def initialize(args = {})
|
5
|
-
@name = args[:name]
|
6
|
-
@alias_name = args[:alias_for]
|
7
|
-
@alias_for = Puppet.settings.setting(alias_name)
|
8
|
-
end
|
9
|
-
|
10
|
-
def optparse_args
|
11
|
-
args = @alias_for.optparse_args
|
12
|
-
args[0].gsub!(alias_name.to_s, name.to_s)
|
13
|
-
args
|
14
|
-
end
|
15
|
-
|
16
|
-
def getopt_args
|
17
|
-
args = @alias_for.getopt_args
|
18
|
-
args[0].gsub!(alias_name.to_s, name.to_s)
|
19
|
-
args
|
20
|
-
end
|
21
|
-
|
22
|
-
def type
|
23
|
-
:alias
|
24
|
-
end
|
25
|
-
|
26
|
-
def method_missing(method, *args)
|
27
|
-
begin
|
28
|
-
alias_for.send(method, *args)
|
29
|
-
rescue => e
|
30
|
-
Puppet.log_exception(self.class, e.message)
|
31
|
-
end
|
32
|
-
end
|
33
|
-
|
34
|
-
private
|
35
|
-
|
36
|
-
attr_reader :alias_for
|
37
|
-
end
|