puppet-retrospec 0.7.0 → 0.7.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +7 -3
- data/README.md +8 -0
- data/VERSION +1 -1
- data/bin/retrospec +7 -0
- data/lib/retrospec.rb +1 -0
- data/lib/retrospec/helpers.rb +1 -1
- data/lib/retrospec/version.rb +2 -2
- data/puppet-retrospec.gemspec +1268 -9
- data/vendor/gems/puppet-3.7.3/COMMITTERS.md +244 -0
- data/vendor/gems/puppet-3.7.3/CONTRIBUTING.md +91 -0
- data/vendor/gems/puppet-3.7.3/Gemfile +102 -0
- data/vendor/gems/puppet-3.7.3/LICENSE +17 -0
- data/vendor/gems/puppet-3.7.3/README.md +76 -0
- data/vendor/gems/puppet-3.7.3/Rakefile +68 -0
- data/vendor/gems/puppet-3.7.3/bin/extlookup2hiera +56 -0
- data/vendor/gems/puppet-3.7.3/bin/puppet +8 -0
- data/vendor/gems/puppet-3.7.3/conf/auth.conf +120 -0
- data/vendor/gems/puppet-3.7.3/conf/fileserver.conf +42 -0
- data/vendor/gems/puppet-3.7.3/conf/tagmail.conf +16 -0
- data/vendor/gems/puppet-3.7.3/install.rb +429 -0
- data/vendor/gems/puppet-3.7.3/lib/hiera/backend/puppet_backend.rb +103 -0
- data/vendor/gems/puppet-3.7.3/lib/hiera/scope.rb +60 -0
- data/vendor/gems/puppet-3.7.3/lib/hiera_puppet.rb +87 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet.rb +277 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/agent.rb +121 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/agent/disabler.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/agent/locker.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application.rb +513 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/agent.rb +480 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/apply.rb +299 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/ca.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/catalog.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/cert.rb +277 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/certificate.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/certificate_request.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/certificate_revocation_list.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/config.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/describe.rb +254 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/device.rb +238 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/doc.rb +273 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/face_base.rb +250 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/facts.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/file.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/filebucket.rb +184 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/help.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/indirection_base.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/inspect.rb +179 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/instrumentation_data.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/instrumentation_listener.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/instrumentation_probe.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/key.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/kick.rb +351 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/man.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/master.rb +304 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/module.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/node.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/parser.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/plugin.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/queue.rb +161 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/report.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/resource.rb +228 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/resource_type.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/secret_agent.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/application/status.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/bindings.rb +147 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/coercion.rb +40 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/configurer.rb +305 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/downloader.rb +66 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/downloader_factory.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/fact_handler.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/configurer/plugin_handler.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine.rb +80 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine/any.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine/exists.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine/false.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine/feature.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine/true.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine/variable.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confine_collection.rb +50 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/confiner.rb +46 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/context.rb +101 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/context/trusted_information.rb +56 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/daemon.rb +182 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/data_binding.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/defaults.rb +2084 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/dsl.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/dsl/resource_api.rb +120 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/dsl/resource_type_api.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/environments.rb +434 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/error.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/dot.rb +326 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios.rb +46 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/base.rb +472 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/grammar.ry +248 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/makefile +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/nagios/parser.rb +400 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/common.rb +385 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/pure.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/pure/generator.rb +394 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/pure/parser.rb +318 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/external/pson/version.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/ca.rb +254 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/catalog.rb +130 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/catalog/select.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/certificate.rb +160 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/certificate_request.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/certificate_revocation_list.rb +58 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/config.rb +119 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/facts.rb +81 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/file.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/file/download.rb +57 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/file/store.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/help.rb +194 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/action.erb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/face.erb +111 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/global.erb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/help/man.erb +152 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/instrumentation_data.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/instrumentation_listener.rb +98 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/instrumentation_probe.rb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/key.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/man.rb +99 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/build.rb +63 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/changes.rb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/generate.rb +251 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/install.rb +145 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/list.rb +275 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/search.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/uninstall.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/module/upgrade.rb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/node.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/node/clean.rb +159 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/parser.rb +160 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/plugin.rb +65 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/report.rb +54 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/resource.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/resource_type.rb +81 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/secret_agent.rb +54 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/face/status.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/base.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/cfacter.rb +14 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/eventlog.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/external_facts.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/libuser.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/msgpack.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/pe_license.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/pson.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rack.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rails.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rdoc1.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/rubygems.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/selinux.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/ssh.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/stomp.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/feature/zlib.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_bucket.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_bucket/dipper.rb +119 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_bucket/file.rb +157 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_collection.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_collection/lookup.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/base.rb +95 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/configuration.rb +109 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/configuration/parser.rb +121 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/content.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/fileset.rb +172 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/metadata.rb +199 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount.rb +39 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/file.rb +121 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/modules.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/pluginfacts.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/mount/plugins.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/terminus_helper.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_serving/terminus_selector.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system.rb +366 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file18.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file19.rb +46 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file19windows.rb +107 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/file_impl.rb +145 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/memory_file.rb +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/memory_impl.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/path_pattern.rb +97 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/file_system/uniquefile.rb +190 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/forge.rb +226 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/forge/cache.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/forge/errors.rb +112 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/forge/repository.rb +182 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions.rb +555 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/assert_type.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/each.rb +111 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/epp.rb +54 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/filter.rb +113 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/import.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/inline_epp.rb +88 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/map.rb +97 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/match.rb +102 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/reduce.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/slice.rb +126 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/functions/with.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/key.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/prioritizer.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/random_prioritizer.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/rb_tree_map.rb +388 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/relationship_graph.rb +246 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/sequential_prioritizer.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/simple_graph.rb +566 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/graph/title_hash_prioritizer.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector.rb +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/active_record.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/active_record.rb +39 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/compiler.rb +182 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/json.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/msgpack.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/queue.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/rest.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/static_compiler.rb +214 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/store_configs.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/catalog/yaml.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/ca.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/disabled_ca.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/file.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate/rest.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/ca.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/disabled_ca.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/file.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/memory.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_request/rest.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/ca.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/disabled_ca.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/file.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_revocation_list/rest.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_status.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_status/file.rb +91 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/certificate_status/rest.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/code.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/couch.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/data_binding/hiera.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/data_binding/none.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/direct_file_server.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/envelope.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/errors.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/exec.rb +38 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/face.rb +139 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/active_record.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/couch.rb +36 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/facter.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/inventory_active_record.rb +110 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/inventory_service.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/memory.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/network_device.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/rest.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/store_configs.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/facts/yaml.rb +82 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_bucket_file/file.rb +142 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_bucket_file/rest.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_bucket_file/selector.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/file.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/file_server.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/rest.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_content/selector.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/file.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/file_server.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/rest.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_metadata/selector.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/file_server.rb +65 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/hiera.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/indirection.rb +336 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_data.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_data/local.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_data/rest.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_listener.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_listener/local.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_listener/rest.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_probe.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_probe/local.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/instrumentation_probe/rest.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/json.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/ca.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/disabled_ca.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/file.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/key/memory.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/ldap.rb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/memory.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/msgpack.rb +82 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/active_record.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/exec.rb +69 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/ldap.rb +257 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/memory.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/msgpack.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/plain.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/rest.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/store_configs.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/write_only_yaml.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/node/yaml.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/none.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/plain.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/queue.rb +80 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/msgpack.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/processor.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/rest.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/report/yaml.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/request.rb +317 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/active_record.rb +104 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/ral.rb +64 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/rest.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/store_configs.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource/validator.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource_type.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource_type/parser.rb +101 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/resource_type/rest.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/rest.rb +267 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/run/local.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/run/rest.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/ssl_file.rb +180 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/status.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/status/local.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/status/rest.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/store_configs.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/terminus.rb +169 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/indirector/yaml.rb +63 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface.rb +235 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/action.rb +374 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/action_builder.rb +149 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/action_manager.rb +101 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/documentation.rb +342 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/face_collection.rb +125 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/option.rb +150 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/option_builder.rb +93 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/interface/option_manager.rb +99 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/loaders.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/metatype/manager.rb +184 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module.rb +339 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool.rb +194 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications.rb +14 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/application.rb +98 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/builder.rb +148 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/checksummer.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/installer.rb +353 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/searcher.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/uninstaller.rb +117 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/unpacker.rb +100 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/applications/upgrader.rb +279 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/checksums.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/contents_description.rb +84 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/dependency.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/base.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/installer.rb +95 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/shared.rb +188 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/uninstaller.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/errors/upgrader.rb +63 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/install_directory.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/installed_modules.rb +98 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/local_tarball.rb +90 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/metadata.rb +209 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/modulefile.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/shared_behaviors.rb +180 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/Gemfile +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/README.md.erb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/Rakefile +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/manifests/init.pp.erb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/metadata.json.erb +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/spec/classes/init_spec.rb.erb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/spec/spec_helper.rb +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/skeleton/templates/generator/tests/init.pp.erb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/tar.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/tar/gnu.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/module_tool/tar/mini.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/auth_config_parser.rb +84 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/authconfig.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/authentication.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/authorization.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/authstore.rb +282 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/client_request.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/format.rb +110 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/format_handler.rb +105 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/format_support.rb +124 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/formats.rb +216 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api.rb +2 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v1.rb +222 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v2.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v2/authorization.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/api/v2/environments.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/compression.rb +118 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/connection.rb +240 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/error.rb +69 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/factory.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/handler.rb +186 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/issues.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/memory_response.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/nocache_pool.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/pool.rb +120 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/rack.rb +33 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/rack/rest.rb +138 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/request.rb +56 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/response.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/route.rb +100 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/session.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/site.rb +39 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/webrick.rb +129 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http/webrick/rest.rb +104 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/http_pool.rb +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/resolver.rb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/rest_controller.rb +2 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/rights.rb +219 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/network/server.rb +39 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/node.rb +184 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/node/environment.rb +595 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/node/facts.rb +155 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parameter.rb +585 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/boolean.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/package_options.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/path.rb +57 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/value.rb +93 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parameter/value_collection.rb +211 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast.rb +129 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/arithmetic_operator.rb +91 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/astarray.rb +50 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/asthash.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/block_expression.rb +40 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/boolean_operator.rb +46 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/branch.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/caseopt.rb +52 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/casestatement.rb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/collection.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/collexpr.rb +109 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/comparison_operator.rb +38 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/definition.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/else.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/function.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/hostclass.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/ifstatement.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/in_operator.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/lambda.rb +135 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/leaf.rb +232 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/match_operator.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/method_call.rb +77 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/minus.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/node.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/nop.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/not.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/pops_bridge.rb +242 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/relationship.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource.rb +67 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_defaults.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_instance.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_override.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resource_reference.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/resourceparam.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/selector.rb +50 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/top_level_construct.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/ast/vardef.rb +38 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/code_merger.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/collector.rb +177 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/compiler.rb +625 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/e4_parser_adapter.rb +81 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/files.rb +137 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions.rb +262 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/assert_type.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/contain.rb +36 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/create_resources.rb +82 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/defined.rb +73 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/digest.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/each.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/epp.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/extlookup.rb +153 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/fail.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/file.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/filter.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/fqdn_rand.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/generate.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera_array.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera_hash.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/hiera_include.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/include.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/inline_epp.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/inline_template.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/lookup.rb +144 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/map.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/match.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/md5.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/realize.rb +14 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/reduce.rb +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/regsubst.rb +116 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/require.rb +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/search.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/sha1.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/shellquote.rb +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/slice.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/split.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/sprintf.rb +36 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/tag.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/tagged.rb +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/template.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/versioncmp.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/functions/with.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/grammar.ra +806 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/lexer.rb +608 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/makefile +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/methods.rb +69 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/parser.rb +2559 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/parser_factory.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/parser_support.rb +195 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/relationship.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/resource.rb +275 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/resource/param.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/scope.rb +906 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/templatewrapper.rb +127 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/type_loader.rb +152 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/parser/yaml_trimmer.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops.rb +118 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/adaptable.rb +190 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/adapters.rb +109 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/binder.rb +393 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/binder_issues.rb +122 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_checker.rb +197 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_composer.rb +175 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_factory.rb +805 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_label_provider.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_loader.rb +88 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_model.rb +68 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_model_dumper.rb +187 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_model_meta.rb +215 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/bindings_validator_factory.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/binder_config.rb +107 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/binder_config_checker.rb +142 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/diagnostic_producer.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/config/issues.rb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/injector.rb +767 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/injector_entry.rb +57 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/key_factory.rb +67 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/lookup.rb +199 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/producers.rb +826 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/scheme_handler/confdir_scheme.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/scheme_handler/module_scheme.rb +84 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/scheme_handler/symbolic_scheme.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/binder/system_bindings.rb +60 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/containment.rb +104 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/access_operator.rb +596 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/callable_mismatch_describer.rb +175 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/callable_signature.rb +100 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/closure.rb +228 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/compare_operator.rb +172 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/epp_evaluator.rb +88 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/evaluator_impl.rb +1115 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/external_syntax_support.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/relationship_operator.rb +157 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/evaluator/runtime3_support.rb +599 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/functions/dispatch.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/functions/dispatcher.rb +70 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/functions/function.rb +77 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/issue_reporter.rb +87 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/issues.rb +548 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/label_provider.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/base_loader.rb +102 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/dependency_loader.rb +60 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/gem_support.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/loader.rb +180 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/loader_paths.rb +118 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/module_loaders.rb +256 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/null_loader.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/ruby_function_instantiator.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/simple_environment_loader.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/static_loader.rb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loader/uri_helper.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/loaders.rb +231 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/ast_transformer.rb +643 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/ast_tree_dumper.rb +386 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/factory.rb +1055 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model.rb +114 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model_label_provider.rb +106 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model_meta.rb +576 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/model_tree_dumper.rb +407 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/model/tree_dumper.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/code_merger.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/egrammar.ra +757 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/eparser.rb +2655 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/epp_parser.rb +51 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/epp_support.rb +247 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/evaluating_parser.rb +140 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/heredoc_support.rb +139 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/interpolation_support.rb +231 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/lexer2.rb +696 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/lexer_support.rb +113 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/locatable.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/locator.rb +291 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/parser_support.rb +242 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/parser/slurp_support.rb +95 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/patterns.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/semantic_error.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/class_loader.rb +129 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/enumeration.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/type_calculator.rb +1703 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/type_factory.rb +432 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/type_parser.rb +475 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/types.rb +397 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/types/types_meta.rb +223 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/utils.rb +142 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/validation.rb +432 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/validation/checker4_0.rb +760 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/validation/validator_factory_4_0.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/visitable.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/pops/visitor.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/property.rb +617 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/property/boolean.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/property/ensure.rb +105 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/property/keyvalue.rb +95 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/property/list.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/property/ordered_list.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider.rb +651 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/aixobject.rb +392 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/augeas/augeas.rb +509 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/cisco.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/command.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/computer/computer.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/confine.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/cron/crontab.rb +260 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec.rb +100 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec/posix.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec/shell.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/exec/windows.rb +55 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/file/posix.rb +136 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/file/windows.rb +104 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/aix.rb +141 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/directoryservice.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/groupadd.rb +85 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/ldap.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/pw.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/group/windows_adsi.rb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/host/parsed.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/interface/cisco.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/ldap.rb +137 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/macauthorization/macauthorization.rb +309 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mailalias/aliases.rb +39 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/maillist/mailman.rb +108 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mcx/mcxcontent.rb +172 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mount.rb +58 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/mount/parsed.rb +123 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/naginator.rb +63 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice.rb +292 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice/directoryservice.rb +588 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice/objectadd.rb +33 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/nameservice/pw.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/network_device.rb +68 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package.rb +52 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/aix.rb +152 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/appdmg.rb +106 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/apple.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/apt.rb +116 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/aptitude.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/aptrpm.rb +83 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/blastwave.rb +111 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/dpkg.rb +165 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/fink.rb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/freebsd.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/gem.rb +135 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/hpux.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/macports.rb +107 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/msi.rb +125 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/nim.rb +280 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/openbsd.rb +228 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/opkg.rb +76 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pacman.rb +234 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pip.rb +119 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkg.rb +201 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkgdmg.rb +149 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkgin.rb +87 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/pkgutil.rb +186 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/portage.rb +149 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/ports.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/portupgrade.rb +241 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/rpm.rb +187 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/rug.rb +52 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/sun.rb +132 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/sunfreeware.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/up2date.rb +40 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/urpmi.rb +55 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows.rb +113 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows/exe_package.rb +70 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows/msi_package.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/windows/package.rb +92 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/yum.rb +199 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/yumhelper.py +159 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/package/zypper.rb +90 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/parsedfile.rb +459 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/scheduled_task/win32_taskscheduler.rb +558 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/selboolean/getsetsebool.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/selmodule/semodule.rb +134 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/base.rb +106 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/bsd.rb +51 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/daemontools.rb +194 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/debian.rb +64 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/freebsd.rb +143 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/gentoo.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/init.rb +169 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/launchd.rb +353 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/openbsd.rb +342 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/openrc.rb +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/openwrt.rb +36 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/redhat.rb +67 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/runit.rb +111 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/service.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/smf.rb +116 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/src.rb +120 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/systemd.rb +65 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/upstart.rb +355 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/service/windows.rb +106 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/ssh_authorized_key/parsed.rb +105 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/sshkey/parsed.rb +40 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/aix.rb +369 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/directoryservice.rb +685 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/hpux.rb +66 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/ldap.rb +128 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/pw.rb +97 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/user_role_add.rb +210 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/useradd.rb +231 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/user/windows_adsi.rb +99 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/vlan/cisco.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/yumrepo/inifile.rb +300 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/zfs/zfs.rb +83 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/zone/solaris.rb +361 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/provider/zpool/zpool.rb +120 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails.rb +139 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/benchmark.rb +63 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/001_add_created_at_to_all_tables.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/002_remove_duplicated_index_on_all_tables.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/003_add_environment_to_host.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/004_add_inventory_service_tables.rb +36 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/database/schema.rb +136 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/fact_name.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/fact_value.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/host.rb +258 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/inventory_fact.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/inventory_node.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/param_name.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/param_value.rb +74 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/puppet_tag.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/resource.rb +235 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/resource_tag.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/rails/source_file.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/configuration.rb +73 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/function.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/indirection.rb +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/metaparameter.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/providers.rb +119 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/report.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reference/type.rb +116 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/relationship.rb +103 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reports.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reports/http.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reports/log.rb +14 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reports/rrdgraph.rb +128 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reports/store.rb +68 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/reports/tagmail.rb +179 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/resource.rb +605 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/resource/catalog.rb +554 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/resource/status.rb +155 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/resource/type.rb +413 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/resource/type_collection.rb +230 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/resource/type_collection_helper.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/run.rb +109 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/job.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/scheduler.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/splay_job.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/scheduler/timer.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings.rb +1442 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/array_setting.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/autosign_setting.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/base_setting.rb +195 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/boolean_setting.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/config_file.rb +139 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/directory_setting.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/duration_setting.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/enum_setting.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/environment_conf.rb +175 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/errors.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/file_or_directory_setting.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/file_setting.rb +234 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/ini_file.rb +171 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/path_setting.rb +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/priority_setting.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/string_setting.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/terminus_setting.rb +14 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/ttl_setting.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/settings/value_translator.rb +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/base.rb +140 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate.rb +65 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_authority.rb +517 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_authority/autosign_command.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_authority/interface.rb +178 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_factory.rb +219 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_request.rb +299 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_request_attributes.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_revocation_list.rb +110 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/certificate_signer.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/configuration.rb +64 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/digest.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/host.rb +372 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/inventory.rb +55 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/key.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/oids.rb +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/validator.rb +60 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/validator/default_validator.rb +175 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/ssl/validator/no_validator.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/status.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/test/test_helper.rb +243 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/transaction.rb +370 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/additional_resource_generator.rb +126 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/event.rb +107 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/event_manager.rb +122 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/report.rb +383 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/transaction/resource_harness.rb +251 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type.rb +2452 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/augeas.rb +201 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/component.rb +77 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/computer.rb +66 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/cron.rb +488 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/exec.rb +592 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file.rb +933 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/checksum.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/content.rb +241 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/ctime.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/ensure.rb +189 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/group.rb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/mode.rb +168 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/mtime.rb +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/owner.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/selcontext.rb +124 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/source.rb +259 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/target.rb +87 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/file/type.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/filebucket.rb +122 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/group.rb +188 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/host.rb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/interface.rb +116 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/k5login.rb +88 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/macauthorization.rb +167 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/mailalias.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/maillist.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/mcx.rb +98 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/mount.rb +286 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_command.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_contact.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_contactgroup.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_host.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostdependency.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostescalation.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostextinfo.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_hostgroup.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_service.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_servicedependency.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_serviceescalation.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_serviceextinfo.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_servicegroup.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/nagios_timeperiod.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/notify.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/package.rb +466 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/resources.rb +187 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/router.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/schedule.rb +469 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/scheduled_task.rb +169 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/selboolean.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/selmodule.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/service.rb +234 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/ssh_authorized_key.rb +153 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/sshkey.rb +73 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/stage.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/tidy.rb +324 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/user.rb +698 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/vlan.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/whit.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/yumrepo.rb +363 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/zfs.rb +150 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/zone.rb +382 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/type/zpool.rb +91 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util.rb +554 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/autoload.rb +231 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/backups.rb +86 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/cacher.rb +74 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/checksums.rb +202 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/classgen.rb +236 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/colors.rb +217 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/command_line.rb +199 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/command_line/puppet_option_parser.rb +87 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/command_line/trollop.rb +824 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/constant_inflector.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/diff.rb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/docs.rb +128 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/errors.rb +106 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/execution.rb +327 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/execution_stub.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/feature.rb +97 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/file_watcher.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/fileparsing.rb +376 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/filetype.rb +303 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/http_proxy.rb +65 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/inifile.rb +341 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/inline_docs.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instance_loader.rb +81 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation.rb +152 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/data.rb +46 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/indirection_probe.rb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/instrumentable.rb +136 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/listener.rb +72 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/listeners/log.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/instrumentation/listeners/performance.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/json_lockfile.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap.rb +2 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap/connection.rb +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap/generator.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/ldap/manager.rb +278 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/libuser.conf +15 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/libuser.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/limits.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/lockfile.rb +66 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/log.rb +343 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/log/destination.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/log/destinations.rb +232 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/log/rate_limited_logger.rb +40 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/logging.rb +181 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/metaid.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/methodhelper.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/metric.rb +210 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/monkey_patches.rb +225 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/monkey_patches/lines.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/nagios_maker.rb +85 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/base.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco.rb +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco/device.rb +267 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco/facts.rb +72 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/cisco/interface.rb +82 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/config.rb +93 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/ipcalc.rb +68 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport/base.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport/ssh.rb +122 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/network_device/transport/telnet.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/package.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/pidlock.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/platform.rb +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/plugins.rb +82 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/posix.rb +137 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/aggregate.rb +85 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/around_profiler.rb +67 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/logging.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/object_counts.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/profiler/wall_clock.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/provider_features.rb +184 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/pson.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/queue.rb +96 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/queue/stomp.rb +60 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/rails/cache_accumulator.rb +65 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/rails/collection_merger.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/rails/reference_serializer.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/rdoc.rb +96 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/reference.rb +124 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/resource_template.rb +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/retryaction.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/rubygems.rb +75 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/run_mode.rb +82 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/selinux.rb +222 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/ssl.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/storage.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/suidmanager.rb +191 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/symbolic_file_mode.rb +144 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/tag_set.rb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/tagging.rb +56 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/terminal.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/user_attr.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/warnings.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/watched_file.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher/change_watcher.rb +33 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher/periodic_watcher.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/watcher/timer.rb +19 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/access_control_entry.rb +84 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/access_control_list.rb +113 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/adsi.rb +430 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/api_types.rb +255 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/com.rb +224 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/error.rb +83 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/file.rb +401 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/process.rb +354 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/registry.rb +80 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/root_certs.rb +108 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/security.rb +920 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/security_descriptor.rb +62 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/sid.rb +162 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/string.rb +16 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/taskscheduler.rb +1241 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/windows/user.rb +292 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/yaml.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/util/zaml.rb +419 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor.rb +57 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_pathspec.rb +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_rgen.rb +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_safe_yaml.rb +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/load_semantic.rb +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/CHANGELOG.md +2 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/LICENSE +201 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/PUPPET_README.md +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/README.md +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec.rb +121 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec/gitignorespec.rb +275 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec/regexspec.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/pathspec/lib/pathspec/spec.rb +14 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/require_vendored.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/CHANGELOG +197 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/MIT-LICENSE +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/PUPPET_README.md +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/README.rdoc +78 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/Rakefile +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/TODO +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/anounce.txt +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/design_rationale.txt +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/ea_support.rb +54 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/id_store.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel.rb +562 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel_ext.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_metamodel_generator.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_ea_to_uml13.rb +103 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/ea_support/uml13_to_uml13_ea.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/metamodels/uml13_metamodel.rb +559 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/metamodels/uml13_metamodel_ext.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/metamodel_generator.rb +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/mm_ext/ecore_mmgen_ext.rb +91 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/mmgen.rb +28 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/templates/annotations.tpl +37 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/mmgen/templates/metamodel_generator.tpl +172 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/array_extensions.rb +45 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore.rb +218 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_builder_methods.rb +81 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_ext.rb +69 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_interface.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ecore_to_ruby.rb +167 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/ecore/ruby_to_ecore.rb +91 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/environment.rb +129 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/fragment/dump_file_cache.rb +63 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/fragment/fragmented_model.rb +140 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/fragment/model_fragment.rb +289 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/abstract_instantiator.rb +66 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/abstract_xml_instantiator.rb +66 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/default_xml_instantiator.rb +117 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/ecore_xml_instantiator.rb +169 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_instantiator.rb +126 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_parser.rb +331 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/json_parser.y +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/nodebased_xml_instantiator.rb +137 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/qualified_name_resolver.rb +97 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/reference_resolver.rb +128 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/resolution_helper.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/instantiator/xmi11_instantiator.rb +168 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder.rb +224 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/builder_extensions.rb +556 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/builder_runtime.rb +174 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/constant_order_helper.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/data_types.rb +77 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/intermediate/annotation.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/intermediate/feature.rb +168 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/mm_multiple.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/metamodel_builder/module_extension.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder.rb +32 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder/builder_context.rb +334 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder/model_serializer.rb +225 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/model_builder/reference_resolver.rb +156 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/json_serializer.rb +121 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/opposite_reference_filter.rb +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/qualified_name_provider.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/xmi11_serializer.rb +116 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/xmi20_serializer.rb +71 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/serializer/xml_serializer.rb +98 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language.rb +297 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/directory_template_container.rb +83 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/output_handler.rb +87 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/template_container.rb +234 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/template_language/template_helper.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/transformer.rb +475 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/auto_class_creator.rb +61 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/cached_glob.rb +67 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/file_cache_map.rb +124 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/file_change_detector.rb +84 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/method_delegation.rb +114 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/model_comparator.rb +68 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/model_comparator_base.rb +142 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/model_dumper.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/name_helper.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/rgen/util/pattern_matcher.rb +329 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/transformers/ecore_to_uml13.rb +79 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/lib/transformers/uml13_to_ecore.rb +127 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/array_extensions_test.rb +64 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/ea_instantiator_test.rb +35 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/ea_serializer_test.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/ecore_self_test.rb +54 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/environment_test.rb +90 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/json_test.rb +171 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_builder_test.rb +1482 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_from_ecore_test.rb +57 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_order_test.rb +131 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test.rb +98 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/TestModel.rb +70 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/houseMetamodel.ecore +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/houseMetamodel_from_ecore.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/metamodel_roundtrip_test/using_builtin_types.ecore +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/method_delegation_test.rb +178 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/builder_context_test.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/builder_test.rb +242 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/ecore_original.rb +163 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/ecore_original_regenerated.rb +163 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/reference_resolver_test.rb +156 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/serializer_test.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/statemachine_metamodel.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder/test_model/statemachine1.rb +23 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_builder_test.rb +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/model_fragment_test.rb +30 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/output_handler_test.rb +58 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/qualified_name_provider_test.rb +48 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/qualified_name_resolver_test.rb +102 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/reference_resolver_test.rb +117 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/rgen_test.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test.rb +163 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/expected_result1.txt +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/expected_result2.txt +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/expected_result3.txt +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/indentStringTestDefaultIndent.out +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/indentStringTestTabIndent.out +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/callback_indent_test/a.tpl +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/callback_indent_test/b.tpl +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/code/array.tpl +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/content/author.tpl +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/content/chapter.tpl +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/define_local_test/local.tpl +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/define_local_test/test.tpl +8 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/evaluate_test/test.tpl +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/indent_string_test.tpl +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/index/c/cmod.tpl +1 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/index/chapter.tpl +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_backslash_r_test.tpl +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/no_indent.tpl +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/sub1/no_indent.tpl +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test.tpl +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test2.tpl +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/no_indent_test/test3.tpl +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/null_context_test.tpl +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/root.tpl +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/sub1.tpl +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/sub1/sub1.tpl +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/templates/template_resolution_test/test.tpl +4 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/template_language_test/testout.txt +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/class_model_checker.rb +119 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel.eap +0 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel.xml +1029 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ea_testmodel_partial.xml +317 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/ecore_model_checker.rb +101 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/manual_testmodel.xml +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/testmodel/object_model_checker.rb +67 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/transformer_test.rb +254 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/util/file_cache_map_test.rb +99 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/util/pattern_matcher_test.rb +97 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/util_test.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test.rb +160 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_ecore_model_checker.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_ecore_instantiator.rb +53 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_metamodel.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/rgen/test/xml_instantiator_test/simple_xmi_to_ecore.rb +75 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/CHANGES.md +104 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/Gemfile +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/LICENSE.txt +22 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/PUPPET_README.md +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/README.md +179 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/Rakefile +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml.rb +253 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/deep.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/parse/date.rb +27 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/parse/hexadecimal.rb +12 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/parse/sexagesimal.rb +26 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/psych_handler.rb +92 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/psych_resolver.rb +52 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/resolver.rb +94 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/safe_to_ruby_visitor.rb +17 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/syck_hack.rb +36 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/syck_node_monkeypatch.rb +43 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/syck_resolver.rb +38 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform.rb +41 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_boolean.rb +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_date.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_float.rb +33 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_integer.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_nil.rb +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/to_symbol.rb +13 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/transform/transformation_map.rb +47 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/lib/safe_yaml/version.rb +3 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/run_specs_all_ruby_versions.sh +21 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/safe_yaml.gemspec +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/exploit.1.9.2.yaml +2 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/exploit.1.9.3.yaml +2 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/psych_resolver_spec.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/resolver_specs.rb +250 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/safe_yaml_spec.rb +702 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/spec_helper.rb +18 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/support/exploitable_back_door.rb +29 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/syck_resolver_spec.rb +10 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/base64_spec.rb +11 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_date_spec.rb +34 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_float_spec.rb +42 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_integer_spec.rb +59 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml/spec/transform/to_symbol_spec.rb +49 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/safe_yaml_patches.rb +9 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/Gemfile +20 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/PUPPET_README.md +6 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/Rakefile +69 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic.rb +7 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency.rb +181 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/graph.rb +60 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/graph_node.rb +117 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/module_release.rb +46 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/source.rb +25 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/dependency/unsatisfiable_graph.rb +31 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/version.rb +168 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/lib/semantic/version_range.rb +424 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/spec_helper.rb +24 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/graph_node_spec.rb +141 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/graph_spec.rb +162 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/module_release_spec.rb +143 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/source_spec.rb +5 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency/unsatisfiable_graph_spec.rb +44 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/dependency_spec.rb +383 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/version_range_spec.rb +307 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/vendor/semantic/spec/unit/semantic/version_spec.rb +608 -0
- data/vendor/gems/puppet-3.7.3/lib/puppet/version.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppetx.rb +89 -0
- data/vendor/gems/puppet-3.7.3/lib/puppetx/puppet/bindings_scheme_handler.rb +130 -0
- data/vendor/gems/puppet-3.7.3/lib/puppetx/puppet/syntax_checker.rb +91 -0
- data/vendor/gems/puppet-3.7.3/lib/puppetx/puppetlabs/syntax_checkers/json.rb +37 -0
- data/vendor/gems/puppet-3.7.3/lib/semver.rb +124 -0
- data/vendor/gems/puppet-3.7.3/puppet-3.7.3.gemspec +3648 -0
- data/vendor/gems/puppet-3.7.3/tasks/benchmark.rake +144 -0
- data/vendor/gems/puppet-3.7.3/tasks/ci.rake +29 -0
- data/vendor/gems/puppet-3.7.3/tasks/manpages.rake +84 -0
- data/vendor/gems/puppet-3.7.3/tasks/memwalk.rake +195 -0
- data/vendor/gems/puppet-3.7.3/tasks/parallel.rake +408 -0
- data/vendor/gems/puppet-3.7.3/tasks/parser.rake +19 -0
- data/vendor/gems/puppet-3.7.3/tasks/yard.rake +59 -0
- metadata +1351 -35
@@ -0,0 +1,251 @@
|
|
1
|
+
require 'puppet/resource/status'
|
2
|
+
|
3
|
+
class Puppet::Transaction::ResourceHarness
|
4
|
+
NO_ACTION = Object.new
|
5
|
+
|
6
|
+
extend Forwardable
|
7
|
+
def_delegators :@transaction, :relationship_graph
|
8
|
+
|
9
|
+
attr_reader :transaction
|
10
|
+
|
11
|
+
def initialize(transaction)
|
12
|
+
@transaction = transaction
|
13
|
+
end
|
14
|
+
|
15
|
+
def evaluate(resource)
|
16
|
+
status = Puppet::Resource::Status.new(resource)
|
17
|
+
|
18
|
+
begin
|
19
|
+
context = ResourceApplicationContext.from_resource(resource, status)
|
20
|
+
perform_changes(resource, context)
|
21
|
+
|
22
|
+
if status.changed? && ! resource.noop?
|
23
|
+
cache(resource, :synced, Time.now)
|
24
|
+
resource.flush if resource.respond_to?(:flush)
|
25
|
+
end
|
26
|
+
rescue => detail
|
27
|
+
status.failed_because(detail)
|
28
|
+
ensure
|
29
|
+
status.evaluation_time = Time.now - status.time
|
30
|
+
end
|
31
|
+
|
32
|
+
status
|
33
|
+
end
|
34
|
+
|
35
|
+
def scheduled?(resource)
|
36
|
+
return true if Puppet[:ignoreschedules]
|
37
|
+
return true unless schedule = schedule(resource)
|
38
|
+
|
39
|
+
# We use 'checked' here instead of 'synced' because otherwise we'll
|
40
|
+
# end up checking most resources most times, because they will generally
|
41
|
+
# have been synced a long time ago (e.g., a file only gets updated
|
42
|
+
# once a month on the server and its schedule is daily; the last sync time
|
43
|
+
# will have been a month ago, so we'd end up checking every run).
|
44
|
+
schedule.match?(cached(resource, :checked).to_i)
|
45
|
+
end
|
46
|
+
|
47
|
+
def schedule(resource)
|
48
|
+
unless resource.catalog
|
49
|
+
resource.warning "Cannot schedule without a schedule-containing catalog"
|
50
|
+
return nil
|
51
|
+
end
|
52
|
+
|
53
|
+
return nil unless name = resource[:schedule]
|
54
|
+
resource.catalog.resource(:schedule, name) || resource.fail("Could not find schedule #{name}")
|
55
|
+
end
|
56
|
+
|
57
|
+
# Used mostly for scheduling and auditing at this point.
|
58
|
+
def cached(resource, name)
|
59
|
+
Puppet::Util::Storage.cache(resource)[name]
|
60
|
+
end
|
61
|
+
|
62
|
+
# Used mostly for scheduling and auditing at this point.
|
63
|
+
def cache(resource, name, value)
|
64
|
+
Puppet::Util::Storage.cache(resource)[name] = value
|
65
|
+
end
|
66
|
+
|
67
|
+
private
|
68
|
+
|
69
|
+
def perform_changes(resource, context)
|
70
|
+
cache(resource, :checked, Time.now)
|
71
|
+
|
72
|
+
return [] if ! allow_changes?(resource)
|
73
|
+
|
74
|
+
# Record the current state in state.yml.
|
75
|
+
context.audited_params.each do |param|
|
76
|
+
cache(resource, param, context.current_values[param])
|
77
|
+
end
|
78
|
+
|
79
|
+
ensure_param = resource.parameter(:ensure)
|
80
|
+
if ensure_param && ensure_param.should
|
81
|
+
ensure_event = sync_if_needed(ensure_param, context)
|
82
|
+
else
|
83
|
+
ensure_event = NO_ACTION
|
84
|
+
end
|
85
|
+
|
86
|
+
if ensure_event == NO_ACTION
|
87
|
+
if context.resource_present?
|
88
|
+
resource.properties.each do |param|
|
89
|
+
sync_if_needed(param, context)
|
90
|
+
end
|
91
|
+
else
|
92
|
+
resource.debug("Nothing to manage: no ensure and the resource doesn't exist")
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
capture_audit_events(resource, context)
|
97
|
+
end
|
98
|
+
|
99
|
+
def allow_changes?(resource)
|
100
|
+
if resource.purging? and resource.deleting? and deps = relationship_graph.dependents(resource) \
|
101
|
+
and ! deps.empty? and deps.detect { |d| ! d.deleting? }
|
102
|
+
deplabel = deps.collect { |r| r.ref }.join(",")
|
103
|
+
plurality = deps.length > 1 ? "":"s"
|
104
|
+
resource.warning "#{deplabel} still depend#{plurality} on me -- not purging"
|
105
|
+
false
|
106
|
+
else
|
107
|
+
true
|
108
|
+
end
|
109
|
+
end
|
110
|
+
|
111
|
+
def sync_if_needed(param, context)
|
112
|
+
historical_value = context.historical_values[param.name]
|
113
|
+
current_value = context.current_values[param.name]
|
114
|
+
do_audit = context.audited_params.include?(param.name)
|
115
|
+
|
116
|
+
begin
|
117
|
+
if param.should && !param.safe_insync?(current_value)
|
118
|
+
event = create_change_event(param, current_value, historical_value)
|
119
|
+
if do_audit
|
120
|
+
event = audit_event(event, param)
|
121
|
+
end
|
122
|
+
|
123
|
+
brief_audit_message = audit_message(param, do_audit, historical_value, current_value)
|
124
|
+
|
125
|
+
if param.noop
|
126
|
+
noop(event, param, current_value, brief_audit_message)
|
127
|
+
else
|
128
|
+
sync(event, param, current_value, brief_audit_message)
|
129
|
+
end
|
130
|
+
|
131
|
+
event
|
132
|
+
else
|
133
|
+
NO_ACTION
|
134
|
+
end
|
135
|
+
rescue => detail
|
136
|
+
# Execution will continue on StandardErrors, just store the event
|
137
|
+
Puppet.log_exception(detail)
|
138
|
+
|
139
|
+
event = create_change_event(param, current_value, historical_value)
|
140
|
+
event.status = "failure"
|
141
|
+
event.message = "change from #{param.is_to_s(current_value)} to #{param.should_to_s(param.should)} failed: #{detail}"
|
142
|
+
event
|
143
|
+
rescue Exception => detail
|
144
|
+
# Execution will halt on Exceptions, they get raised to the application
|
145
|
+
event = create_change_event(param, current_value, historical_value)
|
146
|
+
event.status = "failure"
|
147
|
+
event.message = "change from #{param.is_to_s(current_value)} to #{param.should_to_s(param.should)} failed: #{detail}"
|
148
|
+
raise
|
149
|
+
ensure
|
150
|
+
if event
|
151
|
+
context.record(event)
|
152
|
+
event.send_log
|
153
|
+
context.synced_params << param.name
|
154
|
+
end
|
155
|
+
end
|
156
|
+
end
|
157
|
+
|
158
|
+
def create_change_event(property, current_value, historical_value)
|
159
|
+
event = property.event
|
160
|
+
event.previous_value = current_value
|
161
|
+
event.desired_value = property.should
|
162
|
+
event.historical_value = historical_value
|
163
|
+
|
164
|
+
event
|
165
|
+
end
|
166
|
+
|
167
|
+
# This method is an ugly hack because, given a Time object with nanosecond
|
168
|
+
# resolution, roundtripped through YAML serialization, the Time object will
|
169
|
+
# be truncated to microseconds.
|
170
|
+
# For audit purposes, this code special cases this comparison, and compares
|
171
|
+
# the two objects by their second and microsecond components. tv_sec is the
|
172
|
+
# number of seconds since the epoch, and tv_usec is only the microsecond
|
173
|
+
# portion of time. This compare satisfies compatibility requirements for
|
174
|
+
# Ruby 1.8.7, where to_r does not exist on the Time class.
|
175
|
+
def are_audited_values_equal(a, b)
|
176
|
+
a == b || (a.is_a?(Time) && b.is_a?(Time) && a.tv_sec == b.tv_sec && a.tv_usec == b.tv_usec)
|
177
|
+
end
|
178
|
+
private :are_audited_values_equal
|
179
|
+
|
180
|
+
def audit_event(event, property)
|
181
|
+
event.audited = true
|
182
|
+
event.status = "audit"
|
183
|
+
if !are_audited_values_equal(event.historical_value, event.previous_value)
|
184
|
+
event.message = "audit change: previously recorded value #{property.is_to_s(event.historical_value)} has been changed to #{property.is_to_s(event.previous_value)}"
|
185
|
+
end
|
186
|
+
|
187
|
+
event
|
188
|
+
end
|
189
|
+
|
190
|
+
def audit_message(param, do_audit, historical_value, current_value)
|
191
|
+
if do_audit && historical_value && !are_audited_values_equal(historical_value, current_value)
|
192
|
+
" (previously recorded value was #{param.is_to_s(historical_value)})"
|
193
|
+
else
|
194
|
+
""
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
198
|
+
def noop(event, param, current_value, audit_message)
|
199
|
+
event.message = "current_value #{param.is_to_s(current_value)}, should be #{param.should_to_s(param.should)} (noop)#{audit_message}"
|
200
|
+
event.status = "noop"
|
201
|
+
end
|
202
|
+
|
203
|
+
def sync(event, param, current_value, audit_message)
|
204
|
+
param.sync
|
205
|
+
event.message = "#{param.change_to_s(current_value, param.should)}#{audit_message}"
|
206
|
+
event.status = "success"
|
207
|
+
end
|
208
|
+
|
209
|
+
def capture_audit_events(resource, context)
|
210
|
+
context.audited_params.each do |param_name|
|
211
|
+
if context.historical_values.include?(param_name)
|
212
|
+
if !are_audited_values_equal(context.historical_values[param_name], context.current_values[param_name]) && !context.synced_params.include?(param_name)
|
213
|
+
parameter = resource.parameter(param_name)
|
214
|
+
event = audit_event(create_change_event(parameter,
|
215
|
+
context.current_values[param_name],
|
216
|
+
context.historical_values[param_name]),
|
217
|
+
parameter)
|
218
|
+
event.send_log
|
219
|
+
context.record(event)
|
220
|
+
end
|
221
|
+
else
|
222
|
+
resource.property(param_name).notice "audit change: newly-recorded value #{context.current_values[param_name]}"
|
223
|
+
end
|
224
|
+
end
|
225
|
+
end
|
226
|
+
|
227
|
+
# @api private
|
228
|
+
ResourceApplicationContext = Struct.new(:resource,
|
229
|
+
:current_values,
|
230
|
+
:historical_values,
|
231
|
+
:audited_params,
|
232
|
+
:synced_params,
|
233
|
+
:status) do
|
234
|
+
def self.from_resource(resource, status)
|
235
|
+
ResourceApplicationContext.new(resource,
|
236
|
+
resource.retrieve_resource.to_hash,
|
237
|
+
Puppet::Util::Storage.cache(resource).dup,
|
238
|
+
(resource[:audit] || []).map { |p| p.to_sym },
|
239
|
+
[],
|
240
|
+
status)
|
241
|
+
end
|
242
|
+
|
243
|
+
def resource_present?
|
244
|
+
resource.present?(current_values)
|
245
|
+
end
|
246
|
+
|
247
|
+
def record(event)
|
248
|
+
status << event
|
249
|
+
end
|
250
|
+
end
|
251
|
+
end
|
@@ -0,0 +1,2452 @@
|
|
1
|
+
require 'puppet'
|
2
|
+
require 'puppet/util/log'
|
3
|
+
require 'puppet/util/metric'
|
4
|
+
require 'puppet/property'
|
5
|
+
require 'puppet/parameter'
|
6
|
+
require 'puppet/util'
|
7
|
+
require 'puppet/util/autoload'
|
8
|
+
require 'puppet/metatype/manager'
|
9
|
+
require 'puppet/util/errors'
|
10
|
+
require 'puppet/util/logging'
|
11
|
+
require 'puppet/util/tagging'
|
12
|
+
|
13
|
+
# see the bottom of the file for the rest of the inclusions
|
14
|
+
|
15
|
+
|
16
|
+
module Puppet
|
17
|
+
# The base class for all Puppet types.
|
18
|
+
#
|
19
|
+
# A type describes:
|
20
|
+
#--
|
21
|
+
# * **Attributes** - properties, parameters, and meta-parameters are different types of attributes of a type.
|
22
|
+
# * **Properties** - these are the properties of the managed resource (attributes of the entity being managed; like
|
23
|
+
# a file's owner, group and mode). A property describes two states; the 'is' (current state) and the 'should' (wanted
|
24
|
+
# state).
|
25
|
+
# * **Ensurable** - a set of traits that control the lifecycle (create, remove, etc.) of a managed entity.
|
26
|
+
# There is a default set of operations associated with being _ensurable_, but this can be changed.
|
27
|
+
# * **Name/Identity** - one property is the name/identity of a resource, the _namevar_ that uniquely identifies
|
28
|
+
# one instance of a type from all others.
|
29
|
+
# * **Parameters** - additional attributes of the type (that does not directly related to an instance of the managed
|
30
|
+
# resource; if an operation is recursive or not, where to look for things, etc.). A Parameter (in contrast to Property)
|
31
|
+
# has one current value where a Property has two (current-state and wanted-state).
|
32
|
+
# * **Meta-Parameters** - parameters that are available across all types. A meta-parameter typically has
|
33
|
+
# additional semantics; like the `require` meta-parameter. A new type typically does not add new meta-parameters,
|
34
|
+
# but you need to be aware of their existence so you do not inadvertently shadow an existing meta-parameters.
|
35
|
+
# * **Parent** - a type can have a super type (that it inherits from).
|
36
|
+
# * **Validation** - If not just a basic data type, or an enumeration of symbolic values, it is possible to provide
|
37
|
+
# validation logic for a type, properties and parameters.
|
38
|
+
# * **Munging** - munging/unmunging is the process of turning a value in external representation (as used
|
39
|
+
# by a provider) into an internal representation and vice versa. A Type supports adding custom logic for these.
|
40
|
+
# * **Auto Requirements** - a type can specify automatic relationships to resources to ensure that if they are being
|
41
|
+
# managed, they will be processed before this type.
|
42
|
+
# * **Providers** - a provider is an implementation of a type's behavior - the management of a resource in the
|
43
|
+
# system being managed. A provider is often platform specific and is selected at runtime based on
|
44
|
+
# criteria/predicates specified in the configured providers. See {Puppet::Provider} for details.
|
45
|
+
# * **Device Support** - A type has some support for being applied to a device; i.e. something that is managed
|
46
|
+
# by running logic external to the device itself. There are several methods that deals with type
|
47
|
+
# applicability for these special cases such as {apply_to_device}.
|
48
|
+
#
|
49
|
+
# Additional Concepts:
|
50
|
+
# --
|
51
|
+
# * **Resource-type** - A _resource type_ is a term used to denote the type of a resource; internally a resource
|
52
|
+
# is really an instance of a Ruby class i.e. {Puppet::Resource} which defines its behavior as "resource data".
|
53
|
+
# Conceptually however, a resource is an instance of a subclass of Type (e.g. File), where such a class describes
|
54
|
+
# its interface (what can be said/what is known about a resource of this type),
|
55
|
+
# * **Managed Entity** - This is not a term in general use, but is used here when there is a need to make
|
56
|
+
# a distinction between a resource (a description of what/how something should be managed), and what it is
|
57
|
+
# managing (a file in the file system). The term _managed entity_ is a reference to the "file in the file system"
|
58
|
+
# * **Isomorphism** - the quality of being _isomorphic_ means that two resource instances with the same name
|
59
|
+
# refers to the same managed entity. Or put differently; _an isomorphic name is the identity of a resource_.
|
60
|
+
# As an example, `exec` resources (that executes some command) have the command (i.e. the command line string) as
|
61
|
+
# their name, and these resources are said to be non-isomorphic.
|
62
|
+
#
|
63
|
+
# @note The Type class deals with multiple concerns; some methods provide an internal DSL for convenient definition
|
64
|
+
# of types, other methods deal with various aspects while running; wiring up a resource (expressed in Puppet DSL
|
65
|
+
# or Ruby DSL) with its _resource type_ (i.e. an instance of Type) to enable validation, transformation of values
|
66
|
+
# (munge/unmunge), etc. Lastly, Type is also responsible for dealing with Providers; the concrete implementations
|
67
|
+
# of the behavior that constitutes how a particular Type behaves on a particular type of system (e.g. how
|
68
|
+
# commands are executed on a flavor of Linux, on Windows, etc.). This means that as you are reading through the
|
69
|
+
# documentation of this class, you will be switching between these concepts, as well as switching between
|
70
|
+
# the conceptual level "a resource is an instance of a resource-type" and the actual implementation classes
|
71
|
+
# (Type, Resource, Provider, and various utility and helper classes).
|
72
|
+
#
|
73
|
+
# @api public
|
74
|
+
#
|
75
|
+
#
|
76
|
+
class Type
|
77
|
+
include Puppet::Util
|
78
|
+
include Puppet::Util::Errors
|
79
|
+
include Puppet::Util::Logging
|
80
|
+
include Puppet::Util::Tagging
|
81
|
+
|
82
|
+
# Comparing type instances.
|
83
|
+
include Comparable
|
84
|
+
|
85
|
+
# Compares this type against the given _other_ (type) and returns -1, 0, or +1 depending on the order.
|
86
|
+
# @param other [Object] the object to compare against (produces nil, if not kind of Type}
|
87
|
+
# @return [-1, 0, +1, nil] produces -1 if this type is before the given _other_ type, 0 if equals, and 1 if after.
|
88
|
+
# Returns nil, if the given _other_ is not a kind of Type.
|
89
|
+
# @see Comparable
|
90
|
+
#
|
91
|
+
def <=>(other)
|
92
|
+
# We only order against other types, not arbitrary objects.
|
93
|
+
return nil unless other.is_a? Puppet::Type
|
94
|
+
# Our natural order is based on the reference name we use when comparing
|
95
|
+
# against other type instances.
|
96
|
+
self.ref <=> other.ref
|
97
|
+
end
|
98
|
+
|
99
|
+
# Code related to resource type attributes.
|
100
|
+
class << self
|
101
|
+
include Puppet::Util::ClassGen
|
102
|
+
include Puppet::Util::Warnings
|
103
|
+
|
104
|
+
# @return [Array<Puppet::Property>] The list of declared properties for the resource type.
|
105
|
+
# The returned lists contains instances if Puppet::Property or its subclasses.
|
106
|
+
attr_reader :properties
|
107
|
+
end
|
108
|
+
|
109
|
+
# Returns all the attribute names of the type in the appropriate order.
|
110
|
+
# The {key_attributes} come first, then the {provider}, then the {properties}, and finally
|
111
|
+
# the {parameters} and {metaparams},
|
112
|
+
# all in the order they were specified in the respective files.
|
113
|
+
# @return [Array<String>] all type attribute names in a defined order.
|
114
|
+
#
|
115
|
+
def self.allattrs
|
116
|
+
key_attributes | (parameters & [:provider]) | properties.collect { |property| property.name } | parameters | metaparams
|
117
|
+
end
|
118
|
+
|
119
|
+
# Returns the class associated with the given attribute name.
|
120
|
+
# @param name [String] the name of the attribute to obtain the class for
|
121
|
+
# @return [Class, nil] the class for the given attribute, or nil if the name does not refer to an existing attribute
|
122
|
+
#
|
123
|
+
def self.attrclass(name)
|
124
|
+
@attrclasses ||= {}
|
125
|
+
|
126
|
+
# We cache the value, since this method gets called such a huge number
|
127
|
+
# of times (as in, hundreds of thousands in a given run).
|
128
|
+
unless @attrclasses.include?(name)
|
129
|
+
@attrclasses[name] = case self.attrtype(name)
|
130
|
+
when :property; @validproperties[name]
|
131
|
+
when :meta; @@metaparamhash[name]
|
132
|
+
when :param; @paramhash[name]
|
133
|
+
end
|
134
|
+
end
|
135
|
+
@attrclasses[name]
|
136
|
+
end
|
137
|
+
|
138
|
+
# Returns the attribute type (`:property`, `;param`, `:meta`).
|
139
|
+
# @comment What type of parameter are we dealing with? Cache the results, because
|
140
|
+
# this method gets called so many times.
|
141
|
+
# @return [Symbol] a symbol describing the type of attribute (`:property`, `;param`, `:meta`)
|
142
|
+
#
|
143
|
+
def self.attrtype(attr)
|
144
|
+
@attrtypes ||= {}
|
145
|
+
unless @attrtypes.include?(attr)
|
146
|
+
@attrtypes[attr] = case
|
147
|
+
when @validproperties.include?(attr); :property
|
148
|
+
when @paramhash.include?(attr); :param
|
149
|
+
when @@metaparamhash.include?(attr); :meta
|
150
|
+
end
|
151
|
+
end
|
152
|
+
|
153
|
+
@attrtypes[attr]
|
154
|
+
end
|
155
|
+
|
156
|
+
# Provides iteration over meta-parameters.
|
157
|
+
# @yieldparam p [Puppet::Parameter] each meta parameter
|
158
|
+
# @return [void]
|
159
|
+
#
|
160
|
+
def self.eachmetaparam
|
161
|
+
@@metaparams.each { |p| yield p.name }
|
162
|
+
end
|
163
|
+
|
164
|
+
# Creates a new `ensure` property with configured default values or with configuration by an optional block.
|
165
|
+
# This method is a convenience method for creating a property `ensure` with default accepted values.
|
166
|
+
# If no block is specified, the new `ensure` property will accept the default symbolic
|
167
|
+
# values `:present`, and `:absent` - see {Puppet::Property::Ensure}.
|
168
|
+
# If something else is wanted, pass a block and make calls to {Puppet::Property.newvalue} from this block
|
169
|
+
# to define each possible value. If a block is passed, the defaults are not automatically added to the set of
|
170
|
+
# valid values.
|
171
|
+
#
|
172
|
+
# @note This method will be automatically called without a block if the type implements the methods
|
173
|
+
# specified by {ensurable?}. It is recommended to always call this method and not rely on this automatic
|
174
|
+
# specification to clearly state that the type is ensurable.
|
175
|
+
#
|
176
|
+
# @overload ensurable()
|
177
|
+
# @overload ensurable({|| ... })
|
178
|
+
# @yield [ ] A block evaluated in scope of the new Parameter
|
179
|
+
# @yieldreturn [void]
|
180
|
+
# @return [void]
|
181
|
+
# @dsl type
|
182
|
+
# @api public
|
183
|
+
#
|
184
|
+
def self.ensurable(&block)
|
185
|
+
if block_given?
|
186
|
+
self.newproperty(:ensure, :parent => Puppet::Property::Ensure, &block)
|
187
|
+
else
|
188
|
+
self.newproperty(:ensure, :parent => Puppet::Property::Ensure) do
|
189
|
+
self.defaultvalues
|
190
|
+
end
|
191
|
+
end
|
192
|
+
end
|
193
|
+
|
194
|
+
# Returns true if the type implements the default behavior expected by being _ensurable_ "by default".
|
195
|
+
# A type is _ensurable_ by default if it responds to `:exists`, `:create`, and `:destroy`.
|
196
|
+
# If a type implements these methods and have not already specified that it is _ensurable_, it will be
|
197
|
+
# made so with the defaults specified in {ensurable}.
|
198
|
+
# @return [Boolean] whether the type is _ensurable_ or not.
|
199
|
+
#
|
200
|
+
def self.ensurable?
|
201
|
+
# If the class has all three of these methods defined, then it's
|
202
|
+
# ensurable.
|
203
|
+
[:exists?, :create, :destroy].all? { |method|
|
204
|
+
self.public_method_defined?(method)
|
205
|
+
}
|
206
|
+
end
|
207
|
+
|
208
|
+
# @comment These `apply_to` methods are horrible. They should really be implemented
|
209
|
+
# as part of the usual system of constraints that apply to a type and
|
210
|
+
# provider pair, but were implemented as a separate shadow system.
|
211
|
+
#
|
212
|
+
# @comment We should rip them out in favour of a real constraint pattern around the
|
213
|
+
# target device - whatever that looks like - and not have this additional
|
214
|
+
# magic here. --daniel 2012-03-08
|
215
|
+
#
|
216
|
+
# Makes this type applicable to `:device`.
|
217
|
+
# @return [Symbol] Returns `:device`
|
218
|
+
# @api private
|
219
|
+
#
|
220
|
+
def self.apply_to_device
|
221
|
+
@apply_to = :device
|
222
|
+
end
|
223
|
+
|
224
|
+
# Makes this type applicable to `:host`.
|
225
|
+
# @return [Symbol] Returns `:host`
|
226
|
+
# @api private
|
227
|
+
#
|
228
|
+
def self.apply_to_host
|
229
|
+
@apply_to = :host
|
230
|
+
end
|
231
|
+
|
232
|
+
# Makes this type applicable to `:both` (i.e. `:host` and `:device`).
|
233
|
+
# @return [Symbol] Returns `:both`
|
234
|
+
# @api private
|
235
|
+
#
|
236
|
+
def self.apply_to_all
|
237
|
+
@apply_to = :both
|
238
|
+
end
|
239
|
+
|
240
|
+
# Makes this type apply to `:host` if not already applied to something else.
|
241
|
+
# @return [Symbol] a `:device`, `:host`, or `:both` enumeration
|
242
|
+
# @api private
|
243
|
+
def self.apply_to
|
244
|
+
@apply_to ||= :host
|
245
|
+
end
|
246
|
+
|
247
|
+
# Returns true if this type is applicable to the given target.
|
248
|
+
# @param target [Symbol] should be :device, :host or :target, if anything else, :host is enforced
|
249
|
+
# @return [Boolean] true
|
250
|
+
# @api private
|
251
|
+
#
|
252
|
+
def self.can_apply_to(target)
|
253
|
+
[ target == :device ? :device : :host, :both ].include?(apply_to)
|
254
|
+
end
|
255
|
+
|
256
|
+
# Processes the options for a named parameter.
|
257
|
+
# @param name [String] the name of a parameter
|
258
|
+
# @param options [Hash] a hash of options
|
259
|
+
# @option options [Boolean] :boolean if option set to true, an access method on the form _name_? is added for the param
|
260
|
+
# @return [void]
|
261
|
+
#
|
262
|
+
def self.handle_param_options(name, options)
|
263
|
+
# If it's a boolean parameter, create a method to test the value easily
|
264
|
+
if options[:boolean]
|
265
|
+
define_method(name.to_s + "?") do
|
266
|
+
val = self[name]
|
267
|
+
if val == :true or val == true
|
268
|
+
return true
|
269
|
+
end
|
270
|
+
end
|
271
|
+
end
|
272
|
+
end
|
273
|
+
|
274
|
+
# Is the given parameter a meta-parameter?
|
275
|
+
# @return [Boolean] true if the given parameter is a meta-parameter.
|
276
|
+
#
|
277
|
+
def self.metaparam?(param)
|
278
|
+
@@metaparamhash.include?(param.intern)
|
279
|
+
end
|
280
|
+
|
281
|
+
# Returns the meta-parameter class associated with the given meta-parameter name.
|
282
|
+
# Accepts a `nil` name, and return nil.
|
283
|
+
# @param name [String, nil] the name of a meta-parameter
|
284
|
+
# @return [Class,nil] the class for the given meta-parameter, or `nil` if no such meta-parameter exists, (or if
|
285
|
+
# the given meta-parameter name is `nil`.
|
286
|
+
#
|
287
|
+
def self.metaparamclass(name)
|
288
|
+
return nil if name.nil?
|
289
|
+
@@metaparamhash[name.intern]
|
290
|
+
end
|
291
|
+
|
292
|
+
# Returns all meta-parameter names.
|
293
|
+
# @return [Array<String>] all meta-parameter names
|
294
|
+
#
|
295
|
+
def self.metaparams
|
296
|
+
@@metaparams.collect { |param| param.name }
|
297
|
+
end
|
298
|
+
|
299
|
+
# Returns the documentation for a given meta-parameter of this type.
|
300
|
+
# @param metaparam [Puppet::Parameter] the meta-parameter to get documentation for.
|
301
|
+
# @return [String] the documentation associated with the given meta-parameter, or nil of no such documentation
|
302
|
+
# exists.
|
303
|
+
# @raise if the given metaparam is not a meta-parameter in this type
|
304
|
+
#
|
305
|
+
def self.metaparamdoc(metaparam)
|
306
|
+
@@metaparamhash[metaparam].doc
|
307
|
+
end
|
308
|
+
|
309
|
+
# Creates a new meta-parameter.
|
310
|
+
# This creates a new meta-parameter that is added to this and all inheriting types.
|
311
|
+
# @param name [Symbol] the name of the parameter
|
312
|
+
# @param options [Hash] a hash with options.
|
313
|
+
# @option options [Class<inherits Puppet::Parameter>] :parent (Puppet::Parameter) the super class of this parameter
|
314
|
+
# @option options [Hash{String => Object}] :attributes a hash that is applied to the generated class
|
315
|
+
# by calling setter methods corresponding to this hash's keys/value pairs. This is done before the given
|
316
|
+
# block is evaluated.
|
317
|
+
# @option options [Boolean] :boolean (false) specifies if this is a boolean parameter
|
318
|
+
# @option options [Boolean] :namevar (false) specifies if this parameter is the namevar
|
319
|
+
# @option options [Symbol, Array<Symbol>] :required_features specifies required provider features by name
|
320
|
+
# @return [Class<inherits Puppet::Parameter>] the created parameter
|
321
|
+
# @yield [ ] a required block that is evaluated in the scope of the new meta-parameter
|
322
|
+
# @api public
|
323
|
+
# @dsl type
|
324
|
+
# @todo Verify that this description is ok
|
325
|
+
#
|
326
|
+
def self.newmetaparam(name, options = {}, &block)
|
327
|
+
@@metaparams ||= []
|
328
|
+
@@metaparamhash ||= {}
|
329
|
+
name = name.intern
|
330
|
+
|
331
|
+
param = genclass(
|
332
|
+
name,
|
333
|
+
:parent => options[:parent] || Puppet::Parameter,
|
334
|
+
:prefix => "MetaParam",
|
335
|
+
:hash => @@metaparamhash,
|
336
|
+
:array => @@metaparams,
|
337
|
+
:attributes => options[:attributes],
|
338
|
+
&block
|
339
|
+
)
|
340
|
+
|
341
|
+
# Grr.
|
342
|
+
param.required_features = options[:required_features] if options[:required_features]
|
343
|
+
|
344
|
+
handle_param_options(name, options)
|
345
|
+
|
346
|
+
param.metaparam = true
|
347
|
+
|
348
|
+
param
|
349
|
+
end
|
350
|
+
|
351
|
+
# Returns the list of parameters that comprise the composite key / "uniqueness key".
|
352
|
+
# All parameters that return true from #isnamevar? or is named `:name` are included in the returned result.
|
353
|
+
# @see uniqueness_key
|
354
|
+
# @return [Array<Puppet::Parameter>] WARNING: this return type is uncertain
|
355
|
+
def self.key_attribute_parameters
|
356
|
+
@key_attribute_parameters ||= (
|
357
|
+
@parameters.find_all { |param|
|
358
|
+
param.isnamevar? or param.name == :name
|
359
|
+
}
|
360
|
+
)
|
361
|
+
end
|
362
|
+
|
363
|
+
# Returns cached {key_attribute_parameters} names.
|
364
|
+
# Key attributes are properties and parameters that comprise a composite key
|
365
|
+
# or "uniqueness key".
|
366
|
+
# @return [Array<String>] cached key_attribute names
|
367
|
+
#
|
368
|
+
def self.key_attributes
|
369
|
+
# This is a cache miss around 0.05 percent of the time. --daniel 2012-07-17
|
370
|
+
@key_attributes_cache ||= key_attribute_parameters.collect { |p| p.name }
|
371
|
+
end
|
372
|
+
|
373
|
+
# Returns a mapping from the title string to setting of attribute value(s).
|
374
|
+
# This default implementation provides a mapping of title to the one and only _namevar_ present
|
375
|
+
# in the type's definition.
|
376
|
+
# @note Advanced: some logic requires this mapping to be done differently, using a different
|
377
|
+
# validation/pattern, breaking up the title
|
378
|
+
# into several parts assigning each to an individual attribute, or even use a composite identity where
|
379
|
+
# all namevars are seen as part of the unique identity (such computation is done by the {#uniqueness} method.
|
380
|
+
# These advanced options are rarely used (only one of the built in puppet types use this, and then only
|
381
|
+
# a small part of the available functionality), and the support for these advanced mappings is not
|
382
|
+
# implemented in a straight forward way. For these reasons, this method has been marked as private).
|
383
|
+
#
|
384
|
+
# @raise [Puppet::DevError] if there is no title pattern and there are two or more key attributes
|
385
|
+
# @return [Array<Array<Regexp, Array<Array <Symbol, Proc>>>>, nil] a structure with a regexp and the first key_attribute ???
|
386
|
+
# @comment This wonderful piece of logic creates a structure used by Resource.parse_title which
|
387
|
+
# has the capability to assign parts of the title to one or more attributes; It looks like an implementation
|
388
|
+
# of a composite identity key (all parts of the key_attributes array are in the key). This can also
|
389
|
+
# be seen in the method uniqueness_key.
|
390
|
+
# The implementation in this method simply assigns the title to the one and only namevar (which is name
|
391
|
+
# or a variable marked as namevar).
|
392
|
+
# If there are multiple namevars (any in addition to :name?) then this method MUST be implemented
|
393
|
+
# as it raises an exception if there is more than 1. Note that in puppet, it is only File that uses this
|
394
|
+
# to create a different pattern for assigning to the :path attribute
|
395
|
+
# This requires further digging.
|
396
|
+
# The entire construct is somewhat strange, since resource checks if the method "title_patterns" is
|
397
|
+
# implemented (it seems it always is) - why take this more expensive regexp mathching route for all
|
398
|
+
# other types?
|
399
|
+
# @api private
|
400
|
+
#
|
401
|
+
def self.title_patterns
|
402
|
+
case key_attributes.length
|
403
|
+
when 0; []
|
404
|
+
when 1;
|
405
|
+
[ [ /(.*)/m, [ [key_attributes.first] ] ] ]
|
406
|
+
else
|
407
|
+
raise Puppet::DevError,"you must specify title patterns when there are two or more key attributes"
|
408
|
+
end
|
409
|
+
end
|
410
|
+
|
411
|
+
# Produces a resource's _uniqueness_key_ (or composite key).
|
412
|
+
# This key is an array of all key attributes' values. Each distinct tuple must be unique for each resource type.
|
413
|
+
# @see key_attributes
|
414
|
+
# @return [Object] an object that is a _uniqueness_key_ for this object
|
415
|
+
#
|
416
|
+
def uniqueness_key
|
417
|
+
self.class.key_attributes.sort_by { |attribute_name| attribute_name.to_s }.map{ |attribute_name| self[attribute_name] }
|
418
|
+
end
|
419
|
+
|
420
|
+
# Creates a new parameter.
|
421
|
+
# @param name [Symbol] the name of the parameter
|
422
|
+
# @param options [Hash] a hash with options.
|
423
|
+
# @option options [Class<inherits Puppet::Parameter>] :parent (Puppet::Parameter) the super class of this parameter
|
424
|
+
# @option options [Hash{String => Object}] :attributes a hash that is applied to the generated class
|
425
|
+
# by calling setter methods corresponding to this hash's keys/value pairs. This is done before the given
|
426
|
+
# block is evaluated.
|
427
|
+
# @option options [Boolean] :boolean (false) specifies if this is a boolean parameter
|
428
|
+
# @option options [Boolean] :namevar (false) specifies if this parameter is the namevar
|
429
|
+
# @option options [Symbol, Array<Symbol>] :required_features specifies required provider features by name
|
430
|
+
# @return [Class<inherits Puppet::Parameter>] the created parameter
|
431
|
+
# @yield [ ] a required block that is evaluated in the scope of the new parameter
|
432
|
+
# @api public
|
433
|
+
# @dsl type
|
434
|
+
#
|
435
|
+
def self.newparam(name, options = {}, &block)
|
436
|
+
options[:attributes] ||= {}
|
437
|
+
|
438
|
+
param = genclass(
|
439
|
+
name,
|
440
|
+
:parent => options[:parent] || Puppet::Parameter,
|
441
|
+
:attributes => options[:attributes],
|
442
|
+
:block => block,
|
443
|
+
:prefix => "Parameter",
|
444
|
+
:array => @parameters,
|
445
|
+
:hash => @paramhash
|
446
|
+
)
|
447
|
+
|
448
|
+
handle_param_options(name, options)
|
449
|
+
|
450
|
+
# Grr.
|
451
|
+
param.required_features = options[:required_features] if options[:required_features]
|
452
|
+
|
453
|
+
param.isnamevar if options[:namevar]
|
454
|
+
|
455
|
+
param
|
456
|
+
end
|
457
|
+
|
458
|
+
# Creates a new property.
|
459
|
+
# @param name [Symbol] the name of the property
|
460
|
+
# @param options [Hash] a hash with options.
|
461
|
+
# @option options [Symbol] :array_matching (:first) specifies how the current state is matched against
|
462
|
+
# the wanted state. Use `:first` if the property is single valued, and (`:all`) otherwise.
|
463
|
+
# @option options [Class<inherits Puppet::Property>] :parent (Puppet::Property) the super class of this property
|
464
|
+
# @option options [Hash{String => Object}] :attributes a hash that is applied to the generated class
|
465
|
+
# by calling setter methods corresponding to this hash's keys/value pairs. This is done before the given
|
466
|
+
# block is evaluated.
|
467
|
+
# @option options [Boolean] :boolean (false) specifies if this is a boolean parameter
|
468
|
+
# @option options [Symbol] :retrieve the method to call on the provider (or `parent` if `provider` is not set)
|
469
|
+
# to retrieve the current value of this property.
|
470
|
+
# @option options [Symbol, Array<Symbol>] :required_features specifies required provider features by name
|
471
|
+
# @return [Class<inherits Puppet::Property>] the created property
|
472
|
+
# @yield [ ] a required block that is evaluated in the scope of the new property
|
473
|
+
# @api public
|
474
|
+
# @dsl type
|
475
|
+
#
|
476
|
+
def self.newproperty(name, options = {}, &block)
|
477
|
+
name = name.intern
|
478
|
+
|
479
|
+
# This is here for types that might still have the old method of defining
|
480
|
+
# a parent class.
|
481
|
+
unless options.is_a? Hash
|
482
|
+
raise Puppet::DevError,
|
483
|
+
"Options must be a hash, not #{options.inspect}"
|
484
|
+
end
|
485
|
+
|
486
|
+
raise Puppet::DevError, "Class #{self.name} already has a property named #{name}" if @validproperties.include?(name)
|
487
|
+
|
488
|
+
if parent = options[:parent]
|
489
|
+
options.delete(:parent)
|
490
|
+
else
|
491
|
+
parent = Puppet::Property
|
492
|
+
end
|
493
|
+
|
494
|
+
# We have to create our own, new block here because we want to define
|
495
|
+
# an initial :retrieve method, if told to, and then eval the passed
|
496
|
+
# block if available.
|
497
|
+
prop = genclass(name, :parent => parent, :hash => @validproperties, :attributes => options) do
|
498
|
+
# If they've passed a retrieve method, then override the retrieve
|
499
|
+
# method on the class.
|
500
|
+
if options[:retrieve]
|
501
|
+
define_method(:retrieve) do
|
502
|
+
provider.send(options[:retrieve])
|
503
|
+
end
|
504
|
+
end
|
505
|
+
|
506
|
+
class_eval(&block) if block
|
507
|
+
end
|
508
|
+
|
509
|
+
# If it's the 'ensure' property, always put it first.
|
510
|
+
if name == :ensure
|
511
|
+
@properties.unshift prop
|
512
|
+
else
|
513
|
+
@properties << prop
|
514
|
+
end
|
515
|
+
|
516
|
+
prop
|
517
|
+
end
|
518
|
+
|
519
|
+
def self.paramdoc(param)
|
520
|
+
@paramhash[param].doc
|
521
|
+
end
|
522
|
+
|
523
|
+
# @return [Array<String>] Returns the parameter names
|
524
|
+
def self.parameters
|
525
|
+
return [] unless defined?(@parameters)
|
526
|
+
@parameters.collect { |klass| klass.name }
|
527
|
+
end
|
528
|
+
|
529
|
+
# @return [Puppet::Parameter] Returns the parameter class associated with the given parameter name.
|
530
|
+
def self.paramclass(name)
|
531
|
+
@paramhash[name]
|
532
|
+
end
|
533
|
+
|
534
|
+
# @return [Puppet::Property] Returns the property class ??? associated with the given property name
|
535
|
+
def self.propertybyname(name)
|
536
|
+
@validproperties[name]
|
537
|
+
end
|
538
|
+
|
539
|
+
# Returns whether or not the given name is the name of a property, parameter or meta-parameter
|
540
|
+
# @return [Boolean] true if the given attribute name is the name of an existing property, parameter or meta-parameter
|
541
|
+
#
|
542
|
+
def self.validattr?(name)
|
543
|
+
name = name.intern
|
544
|
+
return true if name == :name
|
545
|
+
@validattrs ||= {}
|
546
|
+
|
547
|
+
unless @validattrs.include?(name)
|
548
|
+
@validattrs[name] = !!(self.validproperty?(name) or self.validparameter?(name) or self.metaparam?(name))
|
549
|
+
end
|
550
|
+
|
551
|
+
@validattrs[name]
|
552
|
+
end
|
553
|
+
|
554
|
+
# @return [Boolean] Returns true if the given name is the name of an existing property
|
555
|
+
def self.validproperty?(name)
|
556
|
+
name = name.intern
|
557
|
+
@validproperties.include?(name) && @validproperties[name]
|
558
|
+
end
|
559
|
+
|
560
|
+
# @return [Array<Symbol>, {}] Returns a list of valid property names, or an empty hash if there are none.
|
561
|
+
# @todo An empty hash is returned if there are no defined parameters (not an empty array). This looks like
|
562
|
+
# a bug.
|
563
|
+
#
|
564
|
+
def self.validproperties
|
565
|
+
return {} unless defined?(@parameters)
|
566
|
+
|
567
|
+
@validproperties.keys
|
568
|
+
end
|
569
|
+
|
570
|
+
# @return [Boolean] Returns true if the given name is the name of an existing parameter
|
571
|
+
def self.validparameter?(name)
|
572
|
+
raise Puppet::DevError, "Class #{self} has not defined parameters" unless defined?(@parameters)
|
573
|
+
!!(@paramhash.include?(name) or @@metaparamhash.include?(name))
|
574
|
+
end
|
575
|
+
|
576
|
+
# (see validattr?)
|
577
|
+
# @note see comment in code - how should this be documented? Are some of the other query methods deprecated?
|
578
|
+
# (or should be).
|
579
|
+
# @comment This is a forward-compatibility method - it's the validity interface we'll use in Puppet::Resource.
|
580
|
+
def self.valid_parameter?(name)
|
581
|
+
validattr?(name)
|
582
|
+
end
|
583
|
+
|
584
|
+
# @return [Boolean] Returns true if the wanted state of the resoure is that it should be absent (i.e. to be deleted).
|
585
|
+
def deleting?
|
586
|
+
obj = @parameters[:ensure] and obj.should == :absent
|
587
|
+
end
|
588
|
+
|
589
|
+
# Creates a new property value holder for the resource if it is valid and does not already exist
|
590
|
+
# @return [Boolean] true if a new parameter was added, false otherwise
|
591
|
+
def add_property_parameter(prop_name)
|
592
|
+
if self.class.validproperty?(prop_name) && !@parameters[prop_name]
|
593
|
+
self.newattr(prop_name)
|
594
|
+
return true
|
595
|
+
end
|
596
|
+
false
|
597
|
+
end
|
598
|
+
|
599
|
+
# @return [Symbol, Boolean] Returns the name of the namevar if there is only one or false otherwise.
|
600
|
+
# @comment This is really convoluted and part of the support for multiple namevars (?).
|
601
|
+
# If there is only one namevar, the produced value is naturally this namevar, but if there are several?
|
602
|
+
# The logic caches the name of the namevar if it is a single name, but otherwise always
|
603
|
+
# calls key_attributes, and then caches the first if there was only one, otherwise it returns
|
604
|
+
# false and caches this (which is then subsequently returned as a cache hit).
|
605
|
+
#
|
606
|
+
def name_var
|
607
|
+
return @name_var_cache unless @name_var_cache.nil?
|
608
|
+
key_attributes = self.class.key_attributes
|
609
|
+
@name_var_cache = (key_attributes.length == 1) && key_attributes.first
|
610
|
+
end
|
611
|
+
|
612
|
+
# Gets the 'should' (wanted state) value of a parameter or property by name.
|
613
|
+
# To explicitly get the 'is' (current state) value use `o.is(:name)`, and to explicitly get the 'should' value
|
614
|
+
# use `o.should(:name)`
|
615
|
+
# @param name [String] the name of the attribute to obtain the 'should' value for.
|
616
|
+
# @return [Object] 'should'/wanted value of the given attribute
|
617
|
+
def [](name)
|
618
|
+
name = name.intern
|
619
|
+
fail("Invalid parameter #{name}(#{name.inspect})") unless self.class.validattr?(name)
|
620
|
+
|
621
|
+
if name == :name && nv = name_var
|
622
|
+
name = nv
|
623
|
+
end
|
624
|
+
|
625
|
+
if obj = @parameters[name]
|
626
|
+
# Note that if this is a property, then the value is the "should" value,
|
627
|
+
# not the current value.
|
628
|
+
obj.value
|
629
|
+
else
|
630
|
+
return nil
|
631
|
+
end
|
632
|
+
end
|
633
|
+
|
634
|
+
# Sets the 'should' (wanted state) value of a property, or the value of a parameter.
|
635
|
+
# @return
|
636
|
+
# @raise [Puppet::Error] if the setting of the value fails, or if the given name is nil.
|
637
|
+
# @raise [Puppet::ResourceError] when the parameter validation raises Puppet::Error or
|
638
|
+
# ArgumentError
|
639
|
+
def []=(name,value)
|
640
|
+
name = name.intern
|
641
|
+
|
642
|
+
fail("Invalid parameter #{name}") unless self.class.validattr?(name)
|
643
|
+
|
644
|
+
if name == :name && nv = name_var
|
645
|
+
name = nv
|
646
|
+
end
|
647
|
+
raise Puppet::Error.new("Got nil value for #{name}") if value.nil?
|
648
|
+
|
649
|
+
property = self.newattr(name)
|
650
|
+
|
651
|
+
if property
|
652
|
+
begin
|
653
|
+
# make sure the parameter doesn't have any errors
|
654
|
+
property.value = value
|
655
|
+
rescue Puppet::Error, ArgumentError => detail
|
656
|
+
error = Puppet::ResourceError.new("Parameter #{name} failed on #{ref}: #{detail}")
|
657
|
+
adderrorcontext(error, detail)
|
658
|
+
raise error
|
659
|
+
end
|
660
|
+
end
|
661
|
+
|
662
|
+
nil
|
663
|
+
end
|
664
|
+
|
665
|
+
# Removes an attribute from the object; useful in testing or in cleanup
|
666
|
+
# when an error has been encountered
|
667
|
+
# @todo Don't know what the attr is (name or Property/Parameter?). Guessing it is a String name...
|
668
|
+
# @todo Is it possible to delete a meta-parameter?
|
669
|
+
# @todo What does delete mean? Is it deleted from the type or is its value state 'is'/'should' deleted?
|
670
|
+
# @param attr [String] the attribute to delete from this object. WHAT IS THE TYPE?
|
671
|
+
# @raise [Puppet::DecError] when an attempt is made to delete an attribute that does not exists.
|
672
|
+
#
|
673
|
+
def delete(attr)
|
674
|
+
attr = attr.intern
|
675
|
+
if @parameters.has_key?(attr)
|
676
|
+
@parameters.delete(attr)
|
677
|
+
else
|
678
|
+
raise Puppet::DevError.new("Undefined attribute '#{attr}' in #{self}")
|
679
|
+
end
|
680
|
+
end
|
681
|
+
|
682
|
+
# Iterates over the properties that were set on this resource.
|
683
|
+
# @yieldparam property [Puppet::Property] each property
|
684
|
+
# @return [void]
|
685
|
+
def eachproperty
|
686
|
+
# properties is a private method
|
687
|
+
properties.each { |property|
|
688
|
+
yield property
|
689
|
+
}
|
690
|
+
end
|
691
|
+
|
692
|
+
# Return the parameters, metaparams, and properties that have a value or were set by a default. Properties are
|
693
|
+
# included since they are a subclass of parameter.
|
694
|
+
# @return [Array<Puppet::Parameter>] Array of parameter objects ( or subclass thereof )
|
695
|
+
def parameters_with_value
|
696
|
+
self.class.allattrs.collect { |attr| parameter(attr) }.compact
|
697
|
+
end
|
698
|
+
|
699
|
+
# Iterates over all parameters with value currently set.
|
700
|
+
# @yieldparam parameter [Puppet::Parameter] or a subclass thereof
|
701
|
+
# @return [void]
|
702
|
+
def eachparameter
|
703
|
+
parameters_with_value.each { |parameter| yield parameter }
|
704
|
+
end
|
705
|
+
|
706
|
+
# Creates a transaction event.
|
707
|
+
# Called by Transaction or by a property.
|
708
|
+
# Merges the given options with the options `:resource`, `:file`, `:line`, and `:tags`, initialized from
|
709
|
+
# values in this object. For possible options to pass (if any ????) see {Puppet::Transaction::Event}.
|
710
|
+
# @todo Needs a better explanation "Why should I care who is calling this method?", What do I need to know
|
711
|
+
# about events and how they work? Where can I read about them?
|
712
|
+
# @param options [Hash] options merged with a fixed set of options defined by this method, passed on to {Puppet::Transaction::Event}.
|
713
|
+
# @return [Puppet::Transaction::Event] the created event
|
714
|
+
def event(options = {})
|
715
|
+
Puppet::Transaction::Event.new({:resource => self, :file => file, :line => line, :tags => tags}.merge(options))
|
716
|
+
end
|
717
|
+
|
718
|
+
# @return [Object, nil] Returns the 'should' (wanted state) value for a specified property, or nil if the
|
719
|
+
# given attribute name is not a property (i.e. if it is a parameter, meta-parameter, or does not exist).
|
720
|
+
def should(name)
|
721
|
+
name = name.intern
|
722
|
+
(prop = @parameters[name] and prop.is_a?(Puppet::Property)) ? prop.should : nil
|
723
|
+
end
|
724
|
+
|
725
|
+
# Registers an attribute to this resource type insance.
|
726
|
+
# Requires either the attribute name or class as its argument.
|
727
|
+
# This is a noop if the named property/parameter is not supported
|
728
|
+
# by this resource. Otherwise, an attribute instance is created
|
729
|
+
# and kept in this resource's parameters hash.
|
730
|
+
# @overload newattr(name)
|
731
|
+
# @param name [Symbol] symbolic name of the attribute
|
732
|
+
# @overload newattr(klass)
|
733
|
+
# @param klass [Class] a class supported as an attribute class, i.e. a subclass of
|
734
|
+
# Parameter or Property
|
735
|
+
# @return [Object] An instance of the named Parameter or Property class associated
|
736
|
+
# to this resource type instance, or nil if the attribute is not supported
|
737
|
+
#
|
738
|
+
def newattr(name)
|
739
|
+
if name.is_a?(Class)
|
740
|
+
klass = name
|
741
|
+
name = klass.name
|
742
|
+
end
|
743
|
+
|
744
|
+
unless klass = self.class.attrclass(name)
|
745
|
+
raise Puppet::Error, "Resource type #{self.class.name} does not support parameter #{name}"
|
746
|
+
end
|
747
|
+
|
748
|
+
if provider and ! provider.class.supports_parameter?(klass)
|
749
|
+
missing = klass.required_features.find_all { |f| ! provider.class.feature?(f) }
|
750
|
+
debug "Provider %s does not support features %s; not managing attribute %s" % [provider.class.name, missing.join(", "), name]
|
751
|
+
return nil
|
752
|
+
end
|
753
|
+
|
754
|
+
return @parameters[name] if @parameters.include?(name)
|
755
|
+
|
756
|
+
@parameters[name] = klass.new(:resource => self)
|
757
|
+
end
|
758
|
+
|
759
|
+
# Returns a string representation of the resource's containment path in
|
760
|
+
# the catalog.
|
761
|
+
# @return [String]
|
762
|
+
def path
|
763
|
+
@path ||= '/' + pathbuilder.join('/')
|
764
|
+
end
|
765
|
+
|
766
|
+
# Returns the value of this object's parameter given by name
|
767
|
+
# @param name [String] the name of the parameter
|
768
|
+
# @return [Object] the value
|
769
|
+
def parameter(name)
|
770
|
+
@parameters[name.to_sym]
|
771
|
+
end
|
772
|
+
|
773
|
+
# Returns a shallow copy of this object's hash of attributes by name.
|
774
|
+
# Note that his not only comprises parameters, but also properties and metaparameters.
|
775
|
+
# Changes to the contained parameters will have an effect on the parameters of this type, but changes to
|
776
|
+
# the returned hash does not.
|
777
|
+
# @return [Hash{String => Object}] a new hash being a shallow copy of the parameters map name to parameter
|
778
|
+
def parameters
|
779
|
+
@parameters.dup
|
780
|
+
end
|
781
|
+
|
782
|
+
# @return [Boolean] Returns whether the attribute given by name has been added
|
783
|
+
# to this resource or not.
|
784
|
+
def propertydefined?(name)
|
785
|
+
name = name.intern unless name.is_a? Symbol
|
786
|
+
@parameters.include?(name)
|
787
|
+
end
|
788
|
+
|
789
|
+
# Returns a {Puppet::Property} instance by name.
|
790
|
+
# To return the value, use 'resource[param]'
|
791
|
+
# @todo LAK:NOTE(20081028) Since the 'parameter' method is now a superset of this method,
|
792
|
+
# this one should probably go away at some point. - Does this mean it should be deprecated ?
|
793
|
+
# @return [Puppet::Property] the property with the given name, or nil if not a property or does not exist.
|
794
|
+
def property(name)
|
795
|
+
(obj = @parameters[name.intern] and obj.is_a?(Puppet::Property)) ? obj : nil
|
796
|
+
end
|
797
|
+
|
798
|
+
# @todo comment says "For any parameters or properties that have defaults and have not yet been
|
799
|
+
# set, set them now. This method can be handed a list of attributes,
|
800
|
+
# and if so it will only set defaults for those attributes."
|
801
|
+
# @todo Needs a better explanation, and investigation about the claim an array can be passed (it is passed
|
802
|
+
# to self.class.attrclass to produce a class on which a check is made if it has a method class :default (does
|
803
|
+
# not seem to support an array...
|
804
|
+
# @return [void]
|
805
|
+
#
|
806
|
+
def set_default(attr)
|
807
|
+
return unless klass = self.class.attrclass(attr)
|
808
|
+
return unless klass.method_defined?(:default)
|
809
|
+
return if @parameters.include?(klass.name)
|
810
|
+
|
811
|
+
return unless parameter = newattr(klass.name)
|
812
|
+
|
813
|
+
if value = parameter.default and ! value.nil?
|
814
|
+
parameter.value = value
|
815
|
+
else
|
816
|
+
@parameters.delete(parameter.name)
|
817
|
+
end
|
818
|
+
end
|
819
|
+
|
820
|
+
# @todo the comment says: "Convert our object to a hash. This just includes properties."
|
821
|
+
# @todo this is confused, again it is the @parameters instance variable that is consulted, and
|
822
|
+
# each value is copied - does it contain "properties" and "parameters" or both? Does it contain
|
823
|
+
# meta-parameters?
|
824
|
+
#
|
825
|
+
# @return [Hash{ ??? => ??? }] a hash of WHAT?. The hash is a shallow copy, any changes to the
|
826
|
+
# objects returned in this hash will be reflected in the original resource having these attributes.
|
827
|
+
#
|
828
|
+
def to_hash
|
829
|
+
rethash = {}
|
830
|
+
|
831
|
+
@parameters.each do |name, obj|
|
832
|
+
rethash[name] = obj.value
|
833
|
+
end
|
834
|
+
|
835
|
+
rethash
|
836
|
+
end
|
837
|
+
|
838
|
+
# @return [String] the name of this object's class
|
839
|
+
# @todo Would that be "file" for the "File" resource type? of "File" or something else?
|
840
|
+
#
|
841
|
+
def type
|
842
|
+
self.class.name
|
843
|
+
end
|
844
|
+
|
845
|
+
# @todo Comment says "Return a specific value for an attribute.", as opposed to what "An upspecific value"???
|
846
|
+
# @todo is this the 'is' or the 'should' value?
|
847
|
+
# @todo why is the return restricted to things that respond to :value? (Only non structural basic data types
|
848
|
+
# supported?
|
849
|
+
#
|
850
|
+
# @return [Object, nil] the value of the attribute having the given name, or nil if the given name is not
|
851
|
+
# an attribute, or the referenced attribute does not respond to `:value`.
|
852
|
+
def value(name)
|
853
|
+
name = name.intern
|
854
|
+
|
855
|
+
(obj = @parameters[name] and obj.respond_to?(:value)) ? obj.value : nil
|
856
|
+
end
|
857
|
+
|
858
|
+
# @todo What is this used for? Needs a better explanation.
|
859
|
+
# @return [???] the version of the catalog or 0 if there is no catalog.
|
860
|
+
def version
|
861
|
+
return 0 unless catalog
|
862
|
+
catalog.version
|
863
|
+
end
|
864
|
+
|
865
|
+
# @return [Array<Puppet::Property>] Returns all of the property objects, in the order specified in the
|
866
|
+
# class.
|
867
|
+
# @todo "what does the 'order specified in the class' mean? The order the properties where added in the
|
868
|
+
# ruby file adding a new type with new properties?
|
869
|
+
#
|
870
|
+
def properties
|
871
|
+
self.class.properties.collect { |prop| @parameters[prop.name] }.compact
|
872
|
+
end
|
873
|
+
|
874
|
+
# Returns true if the type's notion of name is the identity of a resource.
|
875
|
+
# See the overview of this class for a longer explanation of the concept _isomorphism_.
|
876
|
+
# Defaults to true.
|
877
|
+
#
|
878
|
+
# @return [Boolan] true, if this type's name is isomorphic with the object
|
879
|
+
def self.isomorphic?
|
880
|
+
if defined?(@isomorphic)
|
881
|
+
return @isomorphic
|
882
|
+
else
|
883
|
+
return true
|
884
|
+
end
|
885
|
+
end
|
886
|
+
|
887
|
+
# @todo check that this gets documentation (it is at the class level as well as instance).
|
888
|
+
# (see isomorphic?)
|
889
|
+
def isomorphic?
|
890
|
+
self.class.isomorphic?
|
891
|
+
end
|
892
|
+
|
893
|
+
# Returns true if the instance is a managed instance.
|
894
|
+
# A 'yes' here means that the instance was created from the language, vs. being created
|
895
|
+
# in order resolve other questions, such as finding a package in a list.
|
896
|
+
# @note An object that is managed always stays managed, but an object that is not managed
|
897
|
+
# may become managed later in its lifecycle.
|
898
|
+
# @return [Boolean] true if the object is managed
|
899
|
+
def managed?
|
900
|
+
# Once an object is managed, it always stays managed; but an object
|
901
|
+
# that is listed as unmanaged might become managed later in the process,
|
902
|
+
# so we have to check that every time
|
903
|
+
if @managed
|
904
|
+
return @managed
|
905
|
+
else
|
906
|
+
@managed = false
|
907
|
+
properties.each { |property|
|
908
|
+
s = property.should
|
909
|
+
if s and ! property.class.unmanaged
|
910
|
+
@managed = true
|
911
|
+
break
|
912
|
+
end
|
913
|
+
}
|
914
|
+
return @managed
|
915
|
+
end
|
916
|
+
end
|
917
|
+
|
918
|
+
###############################
|
919
|
+
# Code related to the container behaviour.
|
920
|
+
|
921
|
+
# Returns true if the search should be done in depth-first order.
|
922
|
+
# This implementation always returns false.
|
923
|
+
# @todo What is this used for?
|
924
|
+
#
|
925
|
+
# @return [Boolean] true if the search should be done in depth first order.
|
926
|
+
#
|
927
|
+
def depthfirst?
|
928
|
+
false
|
929
|
+
end
|
930
|
+
|
931
|
+
# Removes this object (FROM WHERE?)
|
932
|
+
# @todo removes if from where?
|
933
|
+
# @overload remove(rmdeps)
|
934
|
+
# @deprecated Use remove()
|
935
|
+
# @param rmdeps [Boolean] intended to indicate that all subscriptions should also be removed, ignored.
|
936
|
+
# @overload remove()
|
937
|
+
# @return [void]
|
938
|
+
#
|
939
|
+
def remove(rmdeps = true)
|
940
|
+
# This is hackish (mmm, cut and paste), but it works for now, and it's
|
941
|
+
# better than warnings.
|
942
|
+
@parameters.each do |name, obj|
|
943
|
+
obj.remove
|
944
|
+
end
|
945
|
+
@parameters.clear
|
946
|
+
|
947
|
+
@parent = nil
|
948
|
+
|
949
|
+
# Remove the reference to the provider.
|
950
|
+
if self.provider
|
951
|
+
@provider.clear
|
952
|
+
@provider = nil
|
953
|
+
end
|
954
|
+
end
|
955
|
+
|
956
|
+
###############################
|
957
|
+
# Code related to evaluating the resources.
|
958
|
+
|
959
|
+
# Returns the ancestors - WHAT?
|
960
|
+
# This implementation always returns an empty list.
|
961
|
+
# @todo WHAT IS THIS ?
|
962
|
+
# @return [Array<???>] returns a list of ancestors.
|
963
|
+
def ancestors
|
964
|
+
[]
|
965
|
+
end
|
966
|
+
|
967
|
+
# Lifecycle method for a resource. This is called during graph creation.
|
968
|
+
# It should perform any consistency checking of the catalog and raise a
|
969
|
+
# Puppet::Error if the transaction should be aborted.
|
970
|
+
#
|
971
|
+
# It differs from the validate method, since it is called later during
|
972
|
+
# initialization and can rely on self.catalog to have references to all
|
973
|
+
# resources that comprise the catalog.
|
974
|
+
#
|
975
|
+
# @see Puppet::Transaction#add_vertex
|
976
|
+
# @raise [Puppet::Error] If the pre-run check failed.
|
977
|
+
# @return [void]
|
978
|
+
# @abstract a resource type may implement this method to perform
|
979
|
+
# validation checks that can query the complete catalog
|
980
|
+
def pre_run_check
|
981
|
+
end
|
982
|
+
|
983
|
+
# Flushes the provider if supported by the provider, else no action.
|
984
|
+
# This is called by the transaction.
|
985
|
+
# @todo What does Flushing the provider mean? Why is it interesting to know that this is
|
986
|
+
# called by the transaction? (It is not explained anywhere what a transaction is).
|
987
|
+
#
|
988
|
+
# @return [???, nil] WHAT DOES IT RETURN? GUESS IS VOID
|
989
|
+
def flush
|
990
|
+
self.provider.flush if self.provider and self.provider.respond_to?(:flush)
|
991
|
+
end
|
992
|
+
|
993
|
+
# Returns true if all contained objects are in sync.
|
994
|
+
# @todo "contained in what?" in the given "in" parameter?
|
995
|
+
#
|
996
|
+
# @todo deal with the comment _"FIXME I don't think this is used on the type instances any more,
|
997
|
+
# it's really only used for testing"_
|
998
|
+
# @return [Boolean] true if in sync, false otherwise.
|
999
|
+
#
|
1000
|
+
def insync?(is)
|
1001
|
+
insync = true
|
1002
|
+
|
1003
|
+
if property = @parameters[:ensure]
|
1004
|
+
unless is.include? property
|
1005
|
+
raise Puppet::DevError,
|
1006
|
+
"The is value is not in the is array for '#{property.name}'"
|
1007
|
+
end
|
1008
|
+
ensureis = is[property]
|
1009
|
+
if property.safe_insync?(ensureis) and property.should == :absent
|
1010
|
+
return true
|
1011
|
+
end
|
1012
|
+
end
|
1013
|
+
|
1014
|
+
properties.each { |property|
|
1015
|
+
unless is.include? property
|
1016
|
+
raise Puppet::DevError,
|
1017
|
+
"The is value is not in the is array for '#{property.name}'"
|
1018
|
+
end
|
1019
|
+
|
1020
|
+
propis = is[property]
|
1021
|
+
unless property.safe_insync?(propis)
|
1022
|
+
property.debug("Not in sync: #{propis.inspect} vs #{property.should.inspect}")
|
1023
|
+
insync = false
|
1024
|
+
#else
|
1025
|
+
# property.debug("In sync")
|
1026
|
+
end
|
1027
|
+
}
|
1028
|
+
|
1029
|
+
#self.debug("#{self} sync status is #{insync}")
|
1030
|
+
insync
|
1031
|
+
end
|
1032
|
+
|
1033
|
+
# Retrieves the current value of all contained properties.
|
1034
|
+
# Parameters and meta-parameters are not included in the result.
|
1035
|
+
# @todo As oposed to all non contained properties? How is this different than any of the other
|
1036
|
+
# methods that also "gets" properties/parameters/etc. ?
|
1037
|
+
# @return [Puppet::Resource] array of all property values (mix of types)
|
1038
|
+
# @raise [fail???] if there is a provider and it is not suitable for the host this is evaluated for.
|
1039
|
+
def retrieve
|
1040
|
+
fail "Provider #{provider.class.name} is not functional on this host" if self.provider.is_a?(Puppet::Provider) and ! provider.class.suitable?
|
1041
|
+
|
1042
|
+
result = Puppet::Resource.new(self.class, title)
|
1043
|
+
|
1044
|
+
# Provide the name, so we know we'll always refer to a real thing
|
1045
|
+
result[:name] = self[:name] unless self[:name] == title
|
1046
|
+
|
1047
|
+
if ensure_prop = property(:ensure) or (self.class.validattr?(:ensure) and ensure_prop = newattr(:ensure))
|
1048
|
+
result[:ensure] = ensure_state = ensure_prop.retrieve
|
1049
|
+
else
|
1050
|
+
ensure_state = nil
|
1051
|
+
end
|
1052
|
+
|
1053
|
+
properties.each do |property|
|
1054
|
+
next if property.name == :ensure
|
1055
|
+
if ensure_state == :absent
|
1056
|
+
result[property] = :absent
|
1057
|
+
else
|
1058
|
+
result[property] = property.retrieve
|
1059
|
+
end
|
1060
|
+
end
|
1061
|
+
|
1062
|
+
result
|
1063
|
+
end
|
1064
|
+
|
1065
|
+
# Retrieve the current state of the system as a Puppet::Resource. For
|
1066
|
+
# the base Puppet::Type this does the same thing as #retrieve, but
|
1067
|
+
# specific types are free to implement #retrieve as returning a hash,
|
1068
|
+
# and this will call #retrieve and convert the hash to a resource.
|
1069
|
+
# This is used when determining when syncing a resource.
|
1070
|
+
#
|
1071
|
+
# @return [Puppet::Resource] A resource representing the current state
|
1072
|
+
# of the system.
|
1073
|
+
#
|
1074
|
+
# @api private
|
1075
|
+
def retrieve_resource
|
1076
|
+
resource = retrieve
|
1077
|
+
resource = Resource.new(self.class, title, :parameters => resource) if resource.is_a? Hash
|
1078
|
+
resource
|
1079
|
+
end
|
1080
|
+
|
1081
|
+
# Given the hash of current properties, should this resource be treated as if it
|
1082
|
+
# currently exists on the system. May need to be overridden by types that offer up
|
1083
|
+
# more than just :absent and :present.
|
1084
|
+
def present?(current_values)
|
1085
|
+
current_values[:ensure] != :absent
|
1086
|
+
end
|
1087
|
+
|
1088
|
+
# Returns a hash of the current properties and their values.
|
1089
|
+
# If a resource is absent, its value is the symbol `:absent`
|
1090
|
+
# @return [Hash{Puppet::Property => Object}] mapping of property instance to its value
|
1091
|
+
#
|
1092
|
+
def currentpropvalues
|
1093
|
+
# It's important to use the 'properties' method here, as it follows the order
|
1094
|
+
# in which they're defined in the class. It also guarantees that 'ensure'
|
1095
|
+
# is the first property, which is important for skipping 'retrieve' on
|
1096
|
+
# all the properties if the resource is absent.
|
1097
|
+
ensure_state = false
|
1098
|
+
return properties.inject({}) do | prophash, property|
|
1099
|
+
if property.name == :ensure
|
1100
|
+
ensure_state = property.retrieve
|
1101
|
+
prophash[property] = ensure_state
|
1102
|
+
else
|
1103
|
+
if ensure_state == :absent
|
1104
|
+
prophash[property] = :absent
|
1105
|
+
else
|
1106
|
+
prophash[property] = property.retrieve
|
1107
|
+
end
|
1108
|
+
end
|
1109
|
+
prophash
|
1110
|
+
end
|
1111
|
+
end
|
1112
|
+
|
1113
|
+
# Returns the `noop` run mode status of this.
|
1114
|
+
# @return [Boolean] true if running in noop mode.
|
1115
|
+
def noop?
|
1116
|
+
# If we're not a host_config, we're almost certainly part of
|
1117
|
+
# Settings, and we want to ignore 'noop'
|
1118
|
+
return false if catalog and ! catalog.host_config?
|
1119
|
+
|
1120
|
+
if defined?(@noop)
|
1121
|
+
@noop
|
1122
|
+
else
|
1123
|
+
Puppet[:noop]
|
1124
|
+
end
|
1125
|
+
end
|
1126
|
+
|
1127
|
+
# (see #noop?)
|
1128
|
+
def noop
|
1129
|
+
noop?
|
1130
|
+
end
|
1131
|
+
|
1132
|
+
# Retrieves all known instances.
|
1133
|
+
# @todo Retrieves them from where? Known to whom?
|
1134
|
+
# Either requires providers or must be overridden.
|
1135
|
+
# @raise [Puppet::DevError] when there are no providers and the implementation has not overridded this method.
|
1136
|
+
def self.instances
|
1137
|
+
raise Puppet::DevError, "#{self.name} has no providers and has not overridden 'instances'" if provider_hash.empty?
|
1138
|
+
|
1139
|
+
# Put the default provider first, then the rest of the suitable providers.
|
1140
|
+
provider_instances = {}
|
1141
|
+
providers_by_source.collect do |provider|
|
1142
|
+
self.properties.find_all do |property|
|
1143
|
+
provider.supports_parameter?(property)
|
1144
|
+
end.collect do |property|
|
1145
|
+
property.name
|
1146
|
+
end
|
1147
|
+
|
1148
|
+
provider.instances.collect do |instance|
|
1149
|
+
# We always want to use the "first" provider instance we find, unless the resource
|
1150
|
+
# is already managed and has a different provider set
|
1151
|
+
if other = provider_instances[instance.name]
|
1152
|
+
Puppet.debug "%s %s found in both %s and %s; skipping the %s version" %
|
1153
|
+
[self.name.to_s.capitalize, instance.name, other.class.name, instance.class.name, instance.class.name]
|
1154
|
+
next
|
1155
|
+
end
|
1156
|
+
provider_instances[instance.name] = instance
|
1157
|
+
|
1158
|
+
result = new(:name => instance.name, :provider => instance)
|
1159
|
+
properties.each { |name| result.newattr(name) }
|
1160
|
+
result
|
1161
|
+
end
|
1162
|
+
end.flatten.compact
|
1163
|
+
end
|
1164
|
+
|
1165
|
+
# Returns a list of one suitable provider per source, with the default provider first.
|
1166
|
+
# @todo Needs better explanation; what does "source" mean in this context?
|
1167
|
+
# @return [Array<Puppet::Provider>] list of providers
|
1168
|
+
#
|
1169
|
+
def self.providers_by_source
|
1170
|
+
# Put the default provider first (can be nil), then the rest of the suitable providers.
|
1171
|
+
sources = []
|
1172
|
+
[defaultprovider, suitableprovider].flatten.uniq.collect do |provider|
|
1173
|
+
next if provider.nil?
|
1174
|
+
next if sources.include?(provider.source)
|
1175
|
+
|
1176
|
+
sources << provider.source
|
1177
|
+
provider
|
1178
|
+
end.compact
|
1179
|
+
end
|
1180
|
+
|
1181
|
+
# Converts a simple hash into a Resource instance.
|
1182
|
+
# @todo as opposed to a complex hash? Other raised exceptions?
|
1183
|
+
# @param [Hash{Symbol, String => Object}] hash resource attribute to value map to initialize the created resource from
|
1184
|
+
# @return [Puppet::Resource] the resource created from the hash
|
1185
|
+
# @raise [Puppet::Error] if a title is missing in the given hash
|
1186
|
+
def self.hash2resource(hash)
|
1187
|
+
hash = hash.inject({}) { |result, ary| result[ary[0].to_sym] = ary[1]; result }
|
1188
|
+
|
1189
|
+
title = hash.delete(:title)
|
1190
|
+
title ||= hash[:name]
|
1191
|
+
title ||= hash[key_attributes.first] if key_attributes.length == 1
|
1192
|
+
|
1193
|
+
raise Puppet::Error, "Title or name must be provided" unless title
|
1194
|
+
|
1195
|
+
# Now create our resource.
|
1196
|
+
resource = Puppet::Resource.new(self, title)
|
1197
|
+
resource.catalog = hash.delete(:catalog)
|
1198
|
+
|
1199
|
+
hash.each do |param, value|
|
1200
|
+
resource[param] = value
|
1201
|
+
end
|
1202
|
+
resource
|
1203
|
+
end
|
1204
|
+
|
1205
|
+
|
1206
|
+
# Returns an array of strings representing the containment heirarchy
|
1207
|
+
# (types/classes) that make up the path to the resource from the root
|
1208
|
+
# of the catalog. This is mostly used for logging purposes.
|
1209
|
+
#
|
1210
|
+
# @api private
|
1211
|
+
def pathbuilder
|
1212
|
+
if p = parent
|
1213
|
+
[p.pathbuilder, self.ref].flatten
|
1214
|
+
else
|
1215
|
+
[self.ref]
|
1216
|
+
end
|
1217
|
+
end
|
1218
|
+
|
1219
|
+
###############################
|
1220
|
+
# Add all of the meta-parameters.
|
1221
|
+
newmetaparam(:noop) do
|
1222
|
+
desc "Whether to apply this resource in noop mode.
|
1223
|
+
|
1224
|
+
When applying a resource in noop mode, Puppet will check whether it is in sync,
|
1225
|
+
like it does when running normally. However, if a resource attribute is not in
|
1226
|
+
the desired state (as declared in the catalog), Puppet will take no
|
1227
|
+
action, and will instead report the changes it _would_ have made. These
|
1228
|
+
simulated changes will appear in the report sent to the puppet master, or
|
1229
|
+
be shown on the console if running puppet agent or puppet apply in the
|
1230
|
+
foreground. The simulated changes will not send refresh events to any
|
1231
|
+
subscribing or notified resources, although Puppet will log that a refresh
|
1232
|
+
event _would_ have been sent.
|
1233
|
+
|
1234
|
+
**Important note:**
|
1235
|
+
[The `noop` setting](http://docs.puppetlabs.com/references/latest/configuration.html#noop)
|
1236
|
+
allows you to globally enable or disable noop mode, but it will _not_ override
|
1237
|
+
the `noop` metaparameter on individual resources. That is, the value of the
|
1238
|
+
global `noop` setting will _only_ affect resources that do not have an explicit
|
1239
|
+
value set for their `noop` attribute."
|
1240
|
+
|
1241
|
+
newvalues(:true, :false)
|
1242
|
+
munge do |value|
|
1243
|
+
case value
|
1244
|
+
when true, :true, "true"; @resource.noop = true
|
1245
|
+
when false, :false, "false"; @resource.noop = false
|
1246
|
+
end
|
1247
|
+
end
|
1248
|
+
end
|
1249
|
+
|
1250
|
+
newmetaparam(:schedule) do
|
1251
|
+
desc "A schedule to govern when Puppet is allowed to manage this resource.
|
1252
|
+
The value of this metaparameter must be the `name` of a `schedule`
|
1253
|
+
resource. This means you must declare a schedule resource, then
|
1254
|
+
refer to it by name; see
|
1255
|
+
[the docs for the `schedule` type](http://docs.puppetlabs.com/references/latest/type.html#schedule)
|
1256
|
+
for more info.
|
1257
|
+
|
1258
|
+
schedule { 'everyday':
|
1259
|
+
period => daily,
|
1260
|
+
range => \"2-4\"
|
1261
|
+
}
|
1262
|
+
|
1263
|
+
exec { \"/usr/bin/apt-get update\":
|
1264
|
+
schedule => 'everyday'
|
1265
|
+
}
|
1266
|
+
|
1267
|
+
Note that you can declare the schedule resource anywhere in your
|
1268
|
+
manifests, as long as it ends up in the final compiled catalog."
|
1269
|
+
end
|
1270
|
+
|
1271
|
+
newmetaparam(:audit) do
|
1272
|
+
desc "Marks a subset of this resource's unmanaged attributes for auditing. Accepts an
|
1273
|
+
attribute name, an array of attribute names, or `all`.
|
1274
|
+
|
1275
|
+
Auditing a resource attribute has two effects: First, whenever a catalog
|
1276
|
+
is applied with puppet apply or puppet agent, Puppet will check whether
|
1277
|
+
that attribute of the resource has been modified, comparing its current
|
1278
|
+
value to the previous run; any change will be logged alongside any actions
|
1279
|
+
performed by Puppet while applying the catalog.
|
1280
|
+
|
1281
|
+
Secondly, marking a resource attribute for auditing will include that
|
1282
|
+
attribute in inspection reports generated by puppet inspect; see the
|
1283
|
+
puppet inspect documentation for more details.
|
1284
|
+
|
1285
|
+
Managed attributes for a resource can also be audited, but note that
|
1286
|
+
changes made by Puppet will be logged as additional modifications. (I.e.
|
1287
|
+
if a user manually edits a file whose contents are audited and managed,
|
1288
|
+
puppet agent's next two runs will both log an audit notice: the first run
|
1289
|
+
will log the user's edit and then revert the file to the desired state,
|
1290
|
+
and the second run will log the edit made by Puppet.)"
|
1291
|
+
|
1292
|
+
validate do |list|
|
1293
|
+
list = Array(list).collect {|p| p.to_sym}
|
1294
|
+
unless list == [:all]
|
1295
|
+
list.each do |param|
|
1296
|
+
next if @resource.class.validattr?(param)
|
1297
|
+
fail "Cannot audit #{param}: not a valid attribute for #{resource}"
|
1298
|
+
end
|
1299
|
+
end
|
1300
|
+
end
|
1301
|
+
|
1302
|
+
munge do |args|
|
1303
|
+
properties_to_audit(args).each do |param|
|
1304
|
+
next unless resource.class.validproperty?(param)
|
1305
|
+
resource.newattr(param)
|
1306
|
+
end
|
1307
|
+
end
|
1308
|
+
|
1309
|
+
def all_properties
|
1310
|
+
resource.class.properties.find_all do |property|
|
1311
|
+
resource.provider.nil? or resource.provider.class.supports_parameter?(property)
|
1312
|
+
end.collect do |property|
|
1313
|
+
property.name
|
1314
|
+
end
|
1315
|
+
end
|
1316
|
+
|
1317
|
+
def properties_to_audit(list)
|
1318
|
+
if !list.kind_of?(Array) && list.to_sym == :all
|
1319
|
+
list = all_properties
|
1320
|
+
else
|
1321
|
+
list = Array(list).collect { |p| p.to_sym }
|
1322
|
+
end
|
1323
|
+
end
|
1324
|
+
end
|
1325
|
+
|
1326
|
+
newmetaparam(:loglevel) do
|
1327
|
+
desc "Sets the level that information will be logged.
|
1328
|
+
The log levels have the biggest impact when logs are sent to
|
1329
|
+
syslog (which is currently the default).
|
1330
|
+
|
1331
|
+
The order of the log levels, in decreasing priority, is:
|
1332
|
+
|
1333
|
+
* `crit`
|
1334
|
+
* `emerg`
|
1335
|
+
* `alert`
|
1336
|
+
* `err`
|
1337
|
+
* `warning`
|
1338
|
+
* `notice`
|
1339
|
+
* `info` / `verbose`
|
1340
|
+
* `debug`
|
1341
|
+
"
|
1342
|
+
defaultto :notice
|
1343
|
+
|
1344
|
+
newvalues(*Puppet::Util::Log.levels)
|
1345
|
+
newvalues(:verbose)
|
1346
|
+
|
1347
|
+
munge do |loglevel|
|
1348
|
+
val = super(loglevel)
|
1349
|
+
if val == :verbose
|
1350
|
+
val = :info
|
1351
|
+
end
|
1352
|
+
val
|
1353
|
+
end
|
1354
|
+
end
|
1355
|
+
|
1356
|
+
newmetaparam(:alias) do
|
1357
|
+
desc %q{Creates an alias for the resource. Puppet uses this internally when you
|
1358
|
+
provide a symbolic title and an explicit namevar value:
|
1359
|
+
|
1360
|
+
file { 'sshdconfig':
|
1361
|
+
path => $operatingsystem ? {
|
1362
|
+
solaris => '/usr/local/etc/ssh/sshd_config',
|
1363
|
+
default => '/etc/ssh/sshd_config',
|
1364
|
+
},
|
1365
|
+
source => '...'
|
1366
|
+
}
|
1367
|
+
|
1368
|
+
service { 'sshd':
|
1369
|
+
subscribe => File['sshdconfig'],
|
1370
|
+
}
|
1371
|
+
|
1372
|
+
When you use this feature, the parser sets `sshdconfig` as the title,
|
1373
|
+
and the library sets that as an alias for the file so the dependency
|
1374
|
+
lookup in `Service['sshd']` works. You can use this metaparameter yourself,
|
1375
|
+
but note that aliases generally only work for creating relationships; anything
|
1376
|
+
else that refers to an existing resource (such as amending or overriding
|
1377
|
+
resource attributes in an inherited class) must use the resource's exact
|
1378
|
+
title. For example, the following code will not work:
|
1379
|
+
|
1380
|
+
file { '/etc/ssh/sshd_config':
|
1381
|
+
owner => root,
|
1382
|
+
group => root,
|
1383
|
+
alias => 'sshdconfig',
|
1384
|
+
}
|
1385
|
+
|
1386
|
+
File['sshdconfig'] {
|
1387
|
+
mode => 644,
|
1388
|
+
}
|
1389
|
+
|
1390
|
+
There's no way here for the Puppet parser to know that these two stanzas
|
1391
|
+
should be affecting the same file.
|
1392
|
+
|
1393
|
+
}
|
1394
|
+
|
1395
|
+
munge do |aliases|
|
1396
|
+
aliases = [aliases] unless aliases.is_a?(Array)
|
1397
|
+
|
1398
|
+
raise(ArgumentError, "Cannot add aliases without a catalog") unless @resource.catalog
|
1399
|
+
|
1400
|
+
aliases.each do |other|
|
1401
|
+
if obj = @resource.catalog.resource(@resource.class.name, other)
|
1402
|
+
unless obj.object_id == @resource.object_id
|
1403
|
+
self.fail("#{@resource.title} can not create alias #{other}: object already exists")
|
1404
|
+
end
|
1405
|
+
next
|
1406
|
+
end
|
1407
|
+
|
1408
|
+
# Newschool, add it to the catalog.
|
1409
|
+
@resource.catalog.alias(@resource, other)
|
1410
|
+
end
|
1411
|
+
end
|
1412
|
+
end
|
1413
|
+
|
1414
|
+
newmetaparam(:tag) do
|
1415
|
+
desc "Add the specified tags to the associated resource. While all resources
|
1416
|
+
are automatically tagged with as much information as possible
|
1417
|
+
(e.g., each class and definition containing the resource), it can
|
1418
|
+
be useful to add your own tags to a given resource.
|
1419
|
+
|
1420
|
+
Multiple tags can be specified as an array:
|
1421
|
+
|
1422
|
+
file {'/etc/hosts':
|
1423
|
+
ensure => file,
|
1424
|
+
source => 'puppet:///modules/site/hosts',
|
1425
|
+
mode => 0644,
|
1426
|
+
tag => ['bootstrap', 'minimumrun', 'mediumrun'],
|
1427
|
+
}
|
1428
|
+
|
1429
|
+
Tags are useful for things like applying a subset of a host's configuration
|
1430
|
+
with [the `tags` setting](/references/latest/configuration.html#tags)
|
1431
|
+
(e.g. `puppet agent --test --tags bootstrap`) or filtering alerts with
|
1432
|
+
[the `tagmail` report processor](http://docs.puppetlabs.com/references/latest/report.html#tagmail)."
|
1433
|
+
|
1434
|
+
munge do |tags|
|
1435
|
+
tags = [tags] unless tags.is_a? Array
|
1436
|
+
|
1437
|
+
tags.each do |tag|
|
1438
|
+
@resource.tag(tag)
|
1439
|
+
end
|
1440
|
+
end
|
1441
|
+
end
|
1442
|
+
|
1443
|
+
# RelationshipMetaparam is an implementation supporting the meta-parameters `:require`, `:subscribe`,
|
1444
|
+
# `:notify`, and `:before`.
|
1445
|
+
#
|
1446
|
+
#
|
1447
|
+
class RelationshipMetaparam < Puppet::Parameter
|
1448
|
+
class << self
|
1449
|
+
attr_accessor :direction, :events, :callback, :subclasses
|
1450
|
+
end
|
1451
|
+
|
1452
|
+
@subclasses = []
|
1453
|
+
|
1454
|
+
def self.inherited(sub)
|
1455
|
+
@subclasses << sub
|
1456
|
+
end
|
1457
|
+
|
1458
|
+
# @return [Array<Puppet::Resource>] turns attribute value(s) into list of resources
|
1459
|
+
def munge(references)
|
1460
|
+
references = [references] unless references.is_a?(Array)
|
1461
|
+
references.collect do |ref|
|
1462
|
+
if ref.is_a?(Puppet::Resource)
|
1463
|
+
ref
|
1464
|
+
else
|
1465
|
+
Puppet::Resource.new(ref)
|
1466
|
+
end
|
1467
|
+
end
|
1468
|
+
end
|
1469
|
+
|
1470
|
+
# Checks each reference to assert that what it references exists in the catalog.
|
1471
|
+
#
|
1472
|
+
# @raise [???fail] if the referenced resource can not be found
|
1473
|
+
# @return [void]
|
1474
|
+
def validate_relationship
|
1475
|
+
@value.each do |ref|
|
1476
|
+
unless @resource.catalog.resource(ref.to_s)
|
1477
|
+
description = self.class.direction == :in ? "dependency" : "dependent"
|
1478
|
+
fail ResourceError, "Could not find #{description} #{ref} for #{resource.ref}"
|
1479
|
+
end
|
1480
|
+
end
|
1481
|
+
end
|
1482
|
+
|
1483
|
+
# Creates edges for all relationships.
|
1484
|
+
# The `:in` relationships are specified by the event-receivers, and `:out`
|
1485
|
+
# relationships are specified by the event generator.
|
1486
|
+
# @todo references to "event-receivers" and "event generator" means in this context - are those just
|
1487
|
+
# the resources at the two ends of the relationship?
|
1488
|
+
# This way 'source' and 'target' are consistent terms in both edges
|
1489
|
+
# and events, i.e. an event targets edges whose source matches
|
1490
|
+
# the event's source. The direction of the relationship determines
|
1491
|
+
# which resource is applied first and which resource is considered
|
1492
|
+
# to be the event generator.
|
1493
|
+
# @return [Array<Puppet::Relationship>]
|
1494
|
+
# @raise [???fail] when a reference can not be resolved
|
1495
|
+
#
|
1496
|
+
def to_edges
|
1497
|
+
@value.collect do |reference|
|
1498
|
+
reference.catalog = resource.catalog
|
1499
|
+
|
1500
|
+
# Either of the two retrieval attempts could have returned
|
1501
|
+
# nil.
|
1502
|
+
unless related_resource = reference.resolve
|
1503
|
+
self.fail "Could not retrieve dependency '#{reference}' of #{@resource.ref}"
|
1504
|
+
end
|
1505
|
+
|
1506
|
+
# Are we requiring them, or vice versa? See the method docs
|
1507
|
+
# for futher info on this.
|
1508
|
+
if self.class.direction == :in
|
1509
|
+
source = related_resource
|
1510
|
+
target = @resource
|
1511
|
+
else
|
1512
|
+
source = @resource
|
1513
|
+
target = related_resource
|
1514
|
+
end
|
1515
|
+
|
1516
|
+
if method = self.class.callback
|
1517
|
+
subargs = {
|
1518
|
+
:event => self.class.events,
|
1519
|
+
:callback => method
|
1520
|
+
}
|
1521
|
+
self.debug("subscribes to #{related_resource.ref}")
|
1522
|
+
else
|
1523
|
+
# If there's no callback, there's no point in even adding
|
1524
|
+
# a label.
|
1525
|
+
subargs = nil
|
1526
|
+
self.debug("requires #{related_resource.ref}")
|
1527
|
+
end
|
1528
|
+
|
1529
|
+
Puppet::Relationship.new(source, target, subargs)
|
1530
|
+
end
|
1531
|
+
end
|
1532
|
+
end
|
1533
|
+
|
1534
|
+
# @todo document this, have no clue what this does... it retuns "RelationshipMetaparam.subclasses"
|
1535
|
+
#
|
1536
|
+
def self.relationship_params
|
1537
|
+
RelationshipMetaparam.subclasses
|
1538
|
+
end
|
1539
|
+
|
1540
|
+
|
1541
|
+
# Note that the order in which the relationships params is defined
|
1542
|
+
# matters. The labelled params (notify and subcribe) must be later,
|
1543
|
+
# so that if both params are used, those ones win. It's a hackish
|
1544
|
+
# solution, but it works.
|
1545
|
+
|
1546
|
+
newmetaparam(:require, :parent => RelationshipMetaparam, :attributes => {:direction => :in, :events => :NONE}) do
|
1547
|
+
desc "One or more resources that this resource depends on, expressed as
|
1548
|
+
[resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
|
1549
|
+
Multiple resources can be specified as an array of references. When this
|
1550
|
+
attribute is present:
|
1551
|
+
|
1552
|
+
* The required resource(s) will be applied **before** this resource.
|
1553
|
+
|
1554
|
+
This is one of the four relationship metaparameters, along with
|
1555
|
+
`before`, `notify`, and `subscribe`. For more context, including the
|
1556
|
+
alternate chaining arrow (`->` and `~>`) syntax, see
|
1557
|
+
[the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
|
1558
|
+
end
|
1559
|
+
|
1560
|
+
newmetaparam(:subscribe, :parent => RelationshipMetaparam, :attributes => {:direction => :in, :events => :ALL_EVENTS, :callback => :refresh}) do
|
1561
|
+
desc "One or more resources that this resource depends on, expressed as
|
1562
|
+
[resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
|
1563
|
+
Multiple resources can be specified as an array of references. When this
|
1564
|
+
attribute is present:
|
1565
|
+
|
1566
|
+
* The subscribed resource(s) will be applied _before_ this resource.
|
1567
|
+
* If Puppet makes changes to any of the subscribed resources, it will cause
|
1568
|
+
this resource to _refresh._ (Refresh behavior varies by resource
|
1569
|
+
type: services will restart, mounts will unmount and re-mount, etc. Not
|
1570
|
+
all types can refresh.)
|
1571
|
+
|
1572
|
+
This is one of the four relationship metaparameters, along with
|
1573
|
+
`before`, `require`, and `notify`. For more context, including the
|
1574
|
+
alternate chaining arrow (`->` and `~>`) syntax, see
|
1575
|
+
[the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
|
1576
|
+
end
|
1577
|
+
|
1578
|
+
newmetaparam(:before, :parent => RelationshipMetaparam, :attributes => {:direction => :out, :events => :NONE}) do
|
1579
|
+
desc "One or more resources that depend on this resource, expressed as
|
1580
|
+
[resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
|
1581
|
+
Multiple resources can be specified as an array of references. When this
|
1582
|
+
attribute is present:
|
1583
|
+
|
1584
|
+
* This resource will be applied _before_ the dependent resource(s).
|
1585
|
+
|
1586
|
+
This is one of the four relationship metaparameters, along with
|
1587
|
+
`require`, `notify`, and `subscribe`. For more context, including the
|
1588
|
+
alternate chaining arrow (`->` and `~>`) syntax, see
|
1589
|
+
[the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
|
1590
|
+
end
|
1591
|
+
|
1592
|
+
newmetaparam(:notify, :parent => RelationshipMetaparam, :attributes => {:direction => :out, :events => :ALL_EVENTS, :callback => :refresh}) do
|
1593
|
+
desc "One or more resources that depend on this resource, expressed as
|
1594
|
+
[resource references](http://docs.puppetlabs.com/puppet/latest/reference/lang_datatypes.html#resource-references).
|
1595
|
+
Multiple resources can be specified as an array of references. When this
|
1596
|
+
attribute is present:
|
1597
|
+
|
1598
|
+
* This resource will be applied _before_ the notified resource(s).
|
1599
|
+
* If Puppet makes changes to this resource, it will cause all of the
|
1600
|
+
notified resources to _refresh._ (Refresh behavior varies by resource
|
1601
|
+
type: services will restart, mounts will unmount and re-mount, etc. Not
|
1602
|
+
all types can refresh.)
|
1603
|
+
|
1604
|
+
This is one of the four relationship metaparameters, along with
|
1605
|
+
`before`, `require`, and `subscribe`. For more context, including the
|
1606
|
+
alternate chaining arrow (`->` and `~>`) syntax, see
|
1607
|
+
[the language page on relationships](http://docs.puppetlabs.com/puppet/latest/reference/lang_relationships.html)."
|
1608
|
+
end
|
1609
|
+
|
1610
|
+
newmetaparam(:stage) do
|
1611
|
+
desc %{Which run stage this class should reside in.
|
1612
|
+
|
1613
|
+
**Note: This metaparameter can only be used on classes,** and only when
|
1614
|
+
declaring them with the resource-like syntax. It cannot be used on normal
|
1615
|
+
resources or on classes declared with `include`.
|
1616
|
+
|
1617
|
+
By default, all classes are declared in the `main` stage. To assign a class
|
1618
|
+
to a different stage, you must:
|
1619
|
+
|
1620
|
+
* Declare the new stage as a [`stage` resource](http://docs.puppetlabs.com/references/latest/type.html#stage).
|
1621
|
+
* Declare an order relationship between the new stage and the `main` stage.
|
1622
|
+
* Use the resource-like syntax to declare the class, and set the `stage`
|
1623
|
+
metaparameter to the name of the desired stage.
|
1624
|
+
|
1625
|
+
For example:
|
1626
|
+
|
1627
|
+
stage { 'pre':
|
1628
|
+
before => Stage['main'],
|
1629
|
+
}
|
1630
|
+
|
1631
|
+
class { 'apt-updates':
|
1632
|
+
stage => 'pre',
|
1633
|
+
}
|
1634
|
+
}
|
1635
|
+
end
|
1636
|
+
|
1637
|
+
###############################
|
1638
|
+
# All of the provider plumbing for the resource types.
|
1639
|
+
require 'puppet/provider'
|
1640
|
+
require 'puppet/util/provider_features'
|
1641
|
+
|
1642
|
+
# Add the feature handling module.
|
1643
|
+
extend Puppet::Util::ProviderFeatures
|
1644
|
+
|
1645
|
+
# The provider that has been selected for the instance of the resource type.
|
1646
|
+
# @return [Puppet::Provider,nil] the selected provider or nil, if none has been selected
|
1647
|
+
#
|
1648
|
+
attr_reader :provider
|
1649
|
+
|
1650
|
+
# the Type class attribute accessors
|
1651
|
+
class << self
|
1652
|
+
# The loader of providers to use when loading providers from disk.
|
1653
|
+
# Although it looks like this attribute provides a way to operate with different loaders of
|
1654
|
+
# providers that is not the case; the attribute is written when a new type is created,
|
1655
|
+
# and should not be changed thereafter.
|
1656
|
+
# @api private
|
1657
|
+
#
|
1658
|
+
attr_accessor :providerloader
|
1659
|
+
|
1660
|
+
# @todo Don't know if this is a name, or a reference to a Provider instance (now marked up as an instance
|
1661
|
+
# of Provider.
|
1662
|
+
# @return [Puppet::Provider, nil] The default provider for this type, or nil if non is defines
|
1663
|
+
#
|
1664
|
+
attr_writer :defaultprovider
|
1665
|
+
end
|
1666
|
+
|
1667
|
+
# The default provider, or the most suitable provider if no default provider was set.
|
1668
|
+
# @note a warning will be issued if no default provider has been configured and a search for the most
|
1669
|
+
# suitable provider returns more than one equally suitable provider.
|
1670
|
+
# @return [Puppet::Provider, nil] the default or most suitable provider, or nil if no provider was found
|
1671
|
+
#
|
1672
|
+
def self.defaultprovider
|
1673
|
+
return @defaultprovider if @defaultprovider
|
1674
|
+
|
1675
|
+
suitable = suitableprovider
|
1676
|
+
|
1677
|
+
# Find which providers are a default for this system.
|
1678
|
+
defaults = suitable.find_all { |provider| provider.default? }
|
1679
|
+
|
1680
|
+
# If we don't have any default we use suitable providers
|
1681
|
+
defaults = suitable if defaults.empty?
|
1682
|
+
max = defaults.collect { |provider| provider.specificity }.max
|
1683
|
+
defaults = defaults.find_all { |provider| provider.specificity == max }
|
1684
|
+
|
1685
|
+
if defaults.length > 1
|
1686
|
+
Puppet.warning(
|
1687
|
+
"Found multiple default providers for #{self.name}: #{defaults.collect { |i| i.name.to_s }.join(", ")}; using #{defaults[0].name}"
|
1688
|
+
)
|
1689
|
+
end
|
1690
|
+
|
1691
|
+
@defaultprovider = defaults.shift unless defaults.empty?
|
1692
|
+
end
|
1693
|
+
|
1694
|
+
# @return [Hash{??? => Puppet::Provider}] Returns a hash of WHAT EXACTLY for the given type
|
1695
|
+
# @todo what goes into this hash?
|
1696
|
+
def self.provider_hash_by_type(type)
|
1697
|
+
@provider_hashes ||= {}
|
1698
|
+
@provider_hashes[type] ||= {}
|
1699
|
+
end
|
1700
|
+
|
1701
|
+
# @return [Hash{ ??? => Puppet::Provider}] Returns a hash of WHAT EXACTLY for this type.
|
1702
|
+
# @see provider_hash_by_type method to get the same for some other type
|
1703
|
+
def self.provider_hash
|
1704
|
+
Puppet::Type.provider_hash_by_type(self.name)
|
1705
|
+
end
|
1706
|
+
|
1707
|
+
# Returns the provider having the given name.
|
1708
|
+
# This will load a provider if it is not already loaded. The returned provider is the first found provider
|
1709
|
+
# having the given name, where "first found" semantics is defined by the {providerloader} in use.
|
1710
|
+
#
|
1711
|
+
# @param name [String] the name of the provider to get
|
1712
|
+
# @return [Puppet::Provider, nil] the found provider, or nil if no provider of the given name was found
|
1713
|
+
#
|
1714
|
+
def self.provider(name)
|
1715
|
+
name = name.intern
|
1716
|
+
|
1717
|
+
# If we don't have it yet, try loading it.
|
1718
|
+
@providerloader.load(name) unless provider_hash.has_key?(name)
|
1719
|
+
provider_hash[name]
|
1720
|
+
end
|
1721
|
+
|
1722
|
+
# Returns a list of loaded providers by name.
|
1723
|
+
# This method will not load/search for available providers.
|
1724
|
+
# @return [Array<String>] list of loaded provider names
|
1725
|
+
#
|
1726
|
+
def self.providers
|
1727
|
+
provider_hash.keys
|
1728
|
+
end
|
1729
|
+
|
1730
|
+
# Returns true if the given name is a reference to a provider and if this is a suitable provider for
|
1731
|
+
# this type.
|
1732
|
+
# @todo How does the provider know if it is suitable for the type? Is it just suitable for the platform/
|
1733
|
+
# environment where this method is executing?
|
1734
|
+
# @param name [String] the name of the provider for which validity is checked
|
1735
|
+
# @return [Boolean] true if the given name references a provider that is suitable
|
1736
|
+
#
|
1737
|
+
def self.validprovider?(name)
|
1738
|
+
name = name.intern
|
1739
|
+
|
1740
|
+
(provider_hash.has_key?(name) && provider_hash[name].suitable?)
|
1741
|
+
end
|
1742
|
+
|
1743
|
+
# Creates a new provider of a type.
|
1744
|
+
# This method must be called directly on the type that it's implementing.
|
1745
|
+
# @todo Fix Confusing Explanations!
|
1746
|
+
# Is this a new provider of a Type (metatype), or a provider of an instance of Type (a resource), or
|
1747
|
+
# a Provider (the implementation of a Type's behavior). CONFUSED. It calls magically named methods like
|
1748
|
+
# "providify" ...
|
1749
|
+
# @param name [String, Symbol] the name of the WHAT? provider? type?
|
1750
|
+
# @param options [Hash{Symbol => Object}] a hash of options, used by this method, and passed on to {#genclass}, (see
|
1751
|
+
# it for additional options to pass).
|
1752
|
+
# @option options [Puppet::Provider] :parent the parent provider (what is this?)
|
1753
|
+
# @option options [Puppet::Type] :resource_type the resource type, defaults to this type if unspecified
|
1754
|
+
# @return [Puppet::Provider] a provider ???
|
1755
|
+
# @raise [Puppet::DevError] when the parent provider could not be found.
|
1756
|
+
#
|
1757
|
+
def self.provide(name, options = {}, &block)
|
1758
|
+
name = name.intern
|
1759
|
+
|
1760
|
+
if unprovide(name)
|
1761
|
+
Puppet.debug "Reloading #{name} #{self.name} provider"
|
1762
|
+
end
|
1763
|
+
|
1764
|
+
parent = if pname = options[:parent]
|
1765
|
+
options.delete(:parent)
|
1766
|
+
if pname.is_a? Class
|
1767
|
+
pname
|
1768
|
+
else
|
1769
|
+
if provider = self.provider(pname)
|
1770
|
+
provider
|
1771
|
+
else
|
1772
|
+
raise Puppet::DevError,
|
1773
|
+
"Could not find parent provider #{pname} of #{name}"
|
1774
|
+
end
|
1775
|
+
end
|
1776
|
+
else
|
1777
|
+
Puppet::Provider
|
1778
|
+
end
|
1779
|
+
|
1780
|
+
options[:resource_type] ||= self
|
1781
|
+
|
1782
|
+
self.providify
|
1783
|
+
|
1784
|
+
provider = genclass(
|
1785
|
+
name,
|
1786
|
+
:parent => parent,
|
1787
|
+
:hash => provider_hash,
|
1788
|
+
:prefix => "Provider",
|
1789
|
+
:block => block,
|
1790
|
+
:include => feature_module,
|
1791
|
+
:extend => feature_module,
|
1792
|
+
:attributes => options
|
1793
|
+
)
|
1794
|
+
|
1795
|
+
provider
|
1796
|
+
end
|
1797
|
+
|
1798
|
+
# Ensures there is a `:provider` parameter defined.
|
1799
|
+
# Should only be called if there are providers.
|
1800
|
+
# @return [void]
|
1801
|
+
def self.providify
|
1802
|
+
return if @paramhash.has_key? :provider
|
1803
|
+
|
1804
|
+
newparam(:provider) do
|
1805
|
+
# We're using a hacky way to get the name of our type, since there doesn't
|
1806
|
+
# seem to be a correct way to introspect this at the time this code is run.
|
1807
|
+
# We expect that the class in which this code is executed will be something
|
1808
|
+
# like Puppet::Type::Ssh_authorized_key::ParameterProvider.
|
1809
|
+
desc <<-EOT
|
1810
|
+
The specific backend to use for this `#{self.to_s.split('::')[2].downcase}`
|
1811
|
+
resource. You will seldom need to specify this --- Puppet will usually
|
1812
|
+
discover the appropriate provider for your platform.
|
1813
|
+
EOT
|
1814
|
+
|
1815
|
+
# This is so we can refer back to the type to get a list of
|
1816
|
+
# providers for documentation.
|
1817
|
+
class << self
|
1818
|
+
# The reference to a parent type for the parameter `:provider` used to get a list of
|
1819
|
+
# providers for documentation purposes.
|
1820
|
+
#
|
1821
|
+
attr_accessor :parenttype
|
1822
|
+
end
|
1823
|
+
|
1824
|
+
# Provides the ability to add documentation to a provider.
|
1825
|
+
#
|
1826
|
+
def self.doc
|
1827
|
+
# Since we're mixing @doc with text from other sources, we must normalize
|
1828
|
+
# its indentation with scrub. But we don't need to manually scrub the
|
1829
|
+
# provider's doc string, since markdown_definitionlist sanitizes its inputs.
|
1830
|
+
scrub(@doc) + "Available providers are:\n\n" + parenttype.providers.sort { |a,b|
|
1831
|
+
a.to_s <=> b.to_s
|
1832
|
+
}.collect { |i|
|
1833
|
+
markdown_definitionlist( i, scrub(parenttype().provider(i).doc) )
|
1834
|
+
}.join
|
1835
|
+
end
|
1836
|
+
|
1837
|
+
# For each resource, the provider param defaults to
|
1838
|
+
# the type's default provider
|
1839
|
+
defaultto {
|
1840
|
+
prov = @resource.class.defaultprovider
|
1841
|
+
prov.name if prov
|
1842
|
+
}
|
1843
|
+
|
1844
|
+
validate do |provider_class|
|
1845
|
+
provider_class = provider_class[0] if provider_class.is_a? Array
|
1846
|
+
provider_class = provider_class.class.name if provider_class.is_a?(Puppet::Provider)
|
1847
|
+
|
1848
|
+
unless @resource.class.provider(provider_class)
|
1849
|
+
raise ArgumentError, "Invalid #{@resource.class.name} provider '#{provider_class}'"
|
1850
|
+
end
|
1851
|
+
end
|
1852
|
+
|
1853
|
+
munge do |provider|
|
1854
|
+
provider = provider[0] if provider.is_a? Array
|
1855
|
+
provider = provider.intern if provider.is_a? String
|
1856
|
+
@resource.provider = provider
|
1857
|
+
|
1858
|
+
if provider.is_a?(Puppet::Provider)
|
1859
|
+
provider.class.name
|
1860
|
+
else
|
1861
|
+
provider
|
1862
|
+
end
|
1863
|
+
end
|
1864
|
+
end.parenttype = self
|
1865
|
+
end
|
1866
|
+
|
1867
|
+
# @todo this needs a better explanation
|
1868
|
+
# Removes the implementation class of a given provider.
|
1869
|
+
# @return [Object] returns what {Puppet::Util::ClassGen#rmclass} returns
|
1870
|
+
def self.unprovide(name)
|
1871
|
+
if @defaultprovider and @defaultprovider.name == name
|
1872
|
+
@defaultprovider = nil
|
1873
|
+
end
|
1874
|
+
|
1875
|
+
rmclass(name, :hash => provider_hash, :prefix => "Provider")
|
1876
|
+
end
|
1877
|
+
|
1878
|
+
# Returns a list of suitable providers for the given type.
|
1879
|
+
# A call to this method will load all providers if not already loaded and ask each if it is
|
1880
|
+
# suitable - those that are are included in the result.
|
1881
|
+
# @note This method also does some special processing which rejects a provider named `:fake` (for testing purposes).
|
1882
|
+
# @return [Array<Puppet::Provider>] Returns an array of all suitable providers.
|
1883
|
+
#
|
1884
|
+
def self.suitableprovider
|
1885
|
+
providerloader.loadall if provider_hash.empty?
|
1886
|
+
provider_hash.find_all { |name, provider|
|
1887
|
+
provider.suitable?
|
1888
|
+
}.collect { |name, provider|
|
1889
|
+
provider
|
1890
|
+
}.reject { |p| p.name == :fake } # For testing
|
1891
|
+
end
|
1892
|
+
|
1893
|
+
# @return [Boolean] Returns true if this is something else than a `:provider`, or if it
|
1894
|
+
# is a provider and it is suitable, or if there is a default provider. Otherwise, false is returned.
|
1895
|
+
#
|
1896
|
+
def suitable?
|
1897
|
+
# If we don't use providers, then we consider it suitable.
|
1898
|
+
return true unless self.class.paramclass(:provider)
|
1899
|
+
|
1900
|
+
# We have a provider and it is suitable.
|
1901
|
+
return true if provider && provider.class.suitable?
|
1902
|
+
|
1903
|
+
# We're using the default provider and there is one.
|
1904
|
+
if !provider and self.class.defaultprovider
|
1905
|
+
self.provider = self.class.defaultprovider.name
|
1906
|
+
return true
|
1907
|
+
end
|
1908
|
+
|
1909
|
+
# We specified an unsuitable provider, or there isn't any suitable
|
1910
|
+
# provider.
|
1911
|
+
false
|
1912
|
+
end
|
1913
|
+
|
1914
|
+
# Sets the provider to the given provider/name.
|
1915
|
+
# @overload provider=(name)
|
1916
|
+
# Sets the provider to the result of resolving the name to an instance of Provider.
|
1917
|
+
# @param name [String] the name of the provider
|
1918
|
+
# @overload provider=(provider)
|
1919
|
+
# Sets the provider to the given instances of Provider.
|
1920
|
+
# @param provider [Puppet::Provider] the provider to set
|
1921
|
+
# @return [Puppet::Provider] the provider set
|
1922
|
+
# @raise [ArgumentError] if the provider could not be found/resolved.
|
1923
|
+
#
|
1924
|
+
def provider=(name)
|
1925
|
+
if name.is_a?(Puppet::Provider)
|
1926
|
+
@provider = name
|
1927
|
+
@provider.resource = self
|
1928
|
+
elsif klass = self.class.provider(name)
|
1929
|
+
@provider = klass.new(self)
|
1930
|
+
else
|
1931
|
+
raise ArgumentError, "Could not find #{name} provider of #{self.class.name}"
|
1932
|
+
end
|
1933
|
+
end
|
1934
|
+
|
1935
|
+
###############################
|
1936
|
+
# All of the relationship code.
|
1937
|
+
|
1938
|
+
# Adds a block producing a single name (or list of names) of the given resource type name to autorequire.
|
1939
|
+
# Resources in the catalog that have the named type and a title that is included in the result will be linked
|
1940
|
+
# to the calling resource as a requirement.
|
1941
|
+
#
|
1942
|
+
# @example Autorequire the files File['foo', 'bar']
|
1943
|
+
# autorequire( 'file', {|| ['foo', 'bar'] })
|
1944
|
+
#
|
1945
|
+
# @param name [String] the name of a type of which one or several resources should be autorequired e.g. "file"
|
1946
|
+
# @yield [ ] a block returning list of names of given type to auto require
|
1947
|
+
# @yieldreturn [String, Array<String>] one or several resource names for the named type
|
1948
|
+
# @return [void]
|
1949
|
+
# @dsl type
|
1950
|
+
# @api public
|
1951
|
+
#
|
1952
|
+
def self.autorequire(name, &block)
|
1953
|
+
@autorequires ||= {}
|
1954
|
+
@autorequires[name] = block
|
1955
|
+
end
|
1956
|
+
|
1957
|
+
# Provides iteration over added auto-requirements (see {autorequire}).
|
1958
|
+
# @yieldparam type [String] the name of the type to autoriquire an instance of
|
1959
|
+
# @yieldparam block [Proc] a block producing one or several dependencies to auto require (see {autorequire}).
|
1960
|
+
# @yieldreturn [void]
|
1961
|
+
# @return [void]
|
1962
|
+
def self.eachautorequire
|
1963
|
+
@autorequires ||= {}
|
1964
|
+
@autorequires.each { |type, block|
|
1965
|
+
yield(type, block)
|
1966
|
+
}
|
1967
|
+
end
|
1968
|
+
|
1969
|
+
# Adds dependencies to the catalog from added autorequirements.
|
1970
|
+
# See {autorequire} for how to add an auto-requirement.
|
1971
|
+
# @todo needs details - see the param rel_catalog, and type of this param
|
1972
|
+
# @param rel_catalog [Puppet::Resource::Catalog, nil] the catalog to
|
1973
|
+
# add dependencies to. Defaults to the current catalog (set when the
|
1974
|
+
# type instance was added to a catalog)
|
1975
|
+
# @raise [Puppet::DevError] if there is no catalog
|
1976
|
+
#
|
1977
|
+
def autorequire(rel_catalog = nil)
|
1978
|
+
rel_catalog ||= catalog
|
1979
|
+
raise(Puppet::DevError, "You cannot add relationships without a catalog") unless rel_catalog
|
1980
|
+
|
1981
|
+
reqs = []
|
1982
|
+
self.class.eachautorequire { |type, block|
|
1983
|
+
# Ignore any types we can't find, although that would be a bit odd.
|
1984
|
+
next unless Puppet::Type.type(type)
|
1985
|
+
|
1986
|
+
# Retrieve the list of names from the block.
|
1987
|
+
next unless list = self.instance_eval(&block)
|
1988
|
+
list = [list] unless list.is_a?(Array)
|
1989
|
+
|
1990
|
+
# Collect the current prereqs
|
1991
|
+
list.each { |dep|
|
1992
|
+
# Support them passing objects directly, to save some effort.
|
1993
|
+
unless dep.is_a? Puppet::Type
|
1994
|
+
# Skip autorequires that we aren't managing
|
1995
|
+
unless dep = rel_catalog.resource(type, dep)
|
1996
|
+
next
|
1997
|
+
end
|
1998
|
+
end
|
1999
|
+
|
2000
|
+
reqs << Puppet::Relationship.new(dep, self)
|
2001
|
+
}
|
2002
|
+
}
|
2003
|
+
|
2004
|
+
reqs
|
2005
|
+
end
|
2006
|
+
|
2007
|
+
# Builds the dependencies associated with this resource.
|
2008
|
+
#
|
2009
|
+
# @return [Array<Puppet::Relationship>] list of relationships to other resources
|
2010
|
+
def builddepends
|
2011
|
+
# Handle the requires
|
2012
|
+
self.class.relationship_params.collect do |klass|
|
2013
|
+
if param = @parameters[klass.name]
|
2014
|
+
param.to_edges
|
2015
|
+
end
|
2016
|
+
end.flatten.reject { |r| r.nil? }
|
2017
|
+
end
|
2018
|
+
|
2019
|
+
# Sets the initial list of tags to associate to this resource.
|
2020
|
+
#
|
2021
|
+
# @return [void] ???
|
2022
|
+
def tags=(list)
|
2023
|
+
tag(self.class.name)
|
2024
|
+
tag(*list)
|
2025
|
+
end
|
2026
|
+
|
2027
|
+
# @comment - these two comments were floating around here, and turned up as documentation
|
2028
|
+
# for the attribute "title", much to my surprise and amusement. Clearly these comments
|
2029
|
+
# are orphaned ... I think they can just be removed as what they say should be covered
|
2030
|
+
# by the now added yardoc. <irony>(Yo! to quote some of the other actual awsome specific comments applicable
|
2031
|
+
# to objects called from elsewhere, or not. ;-)</irony>
|
2032
|
+
#
|
2033
|
+
# @comment Types (which map to resources in the languages) are entirely composed of
|
2034
|
+
# attribute value pairs. Generally, Puppet calls any of these things an
|
2035
|
+
# 'attribute', but these attributes always take one of three specific
|
2036
|
+
# forms: parameters, metaparams, or properties.
|
2037
|
+
|
2038
|
+
# @comment In naming methods, I have tried to consistently name the method so
|
2039
|
+
# that it is clear whether it operates on all attributes (thus has 'attr' in
|
2040
|
+
# the method name, or whether it operates on a specific type of attributes.
|
2041
|
+
|
2042
|
+
# The title attribute of WHAT ???
|
2043
|
+
# @todo Figure out what this is the title attribute of (it appears on line 1926 currently).
|
2044
|
+
# @return [String] the title
|
2045
|
+
attr_writer :title
|
2046
|
+
|
2047
|
+
# The noop attribute of WHAT ??? does WHAT???
|
2048
|
+
# @todo Figure out what this is the noop attribute of (it appears on line 1931 currently).
|
2049
|
+
# @return [???] the noop WHAT ??? (mode? if so of what, or noop for an instance of the type, or for all
|
2050
|
+
# instances of a type, or for what???
|
2051
|
+
#
|
2052
|
+
attr_writer :noop
|
2053
|
+
|
2054
|
+
include Enumerable
|
2055
|
+
|
2056
|
+
# class methods dealing with Type management
|
2057
|
+
|
2058
|
+
public
|
2059
|
+
|
2060
|
+
# The Type class attribute accessors
|
2061
|
+
class << self
|
2062
|
+
# @return [String] the name of the resource type; e.g., "File"
|
2063
|
+
#
|
2064
|
+
attr_reader :name
|
2065
|
+
|
2066
|
+
# @return [Boolean] true if the type should send itself a refresh event on change.
|
2067
|
+
#
|
2068
|
+
attr_accessor :self_refresh
|
2069
|
+
include Enumerable, Puppet::Util::ClassGen
|
2070
|
+
include Puppet::MetaType::Manager
|
2071
|
+
|
2072
|
+
include Puppet::Util
|
2073
|
+
include Puppet::Util::Logging
|
2074
|
+
end
|
2075
|
+
|
2076
|
+
# Initializes all of the variables that must be initialized for each subclass.
|
2077
|
+
# @todo Does the explanation make sense?
|
2078
|
+
# @return [void]
|
2079
|
+
def self.initvars
|
2080
|
+
# all of the instances of this class
|
2081
|
+
@objects = Hash.new
|
2082
|
+
@aliases = Hash.new
|
2083
|
+
|
2084
|
+
@defaults = {}
|
2085
|
+
|
2086
|
+
@parameters ||= []
|
2087
|
+
|
2088
|
+
@validproperties = {}
|
2089
|
+
@properties = []
|
2090
|
+
@parameters = []
|
2091
|
+
@paramhash = {}
|
2092
|
+
|
2093
|
+
@paramdoc = Hash.new { |hash,key|
|
2094
|
+
key = key.intern if key.is_a?(String)
|
2095
|
+
if hash.include?(key)
|
2096
|
+
hash[key]
|
2097
|
+
else
|
2098
|
+
"Param Documentation for #{key} not found"
|
2099
|
+
end
|
2100
|
+
}
|
2101
|
+
|
2102
|
+
@doc ||= ""
|
2103
|
+
|
2104
|
+
end
|
2105
|
+
|
2106
|
+
# Returns the name of this type (if specified) or the parent type #to_s.
|
2107
|
+
# The returned name is on the form "Puppet::Type::<name>", where the first letter of name is
|
2108
|
+
# capitalized.
|
2109
|
+
# @return [String] the fully qualified name Puppet::Type::<name> where the first letter of name is captialized
|
2110
|
+
#
|
2111
|
+
def self.to_s
|
2112
|
+
if defined?(@name)
|
2113
|
+
"Puppet::Type::#{@name.to_s.capitalize}"
|
2114
|
+
else
|
2115
|
+
super
|
2116
|
+
end
|
2117
|
+
end
|
2118
|
+
|
2119
|
+
# Creates a `validate` method that is used to validate a resource before it is operated on.
|
2120
|
+
# The validation should raise exceptions if the validation finds errors. (It is not recommended to
|
2121
|
+
# issue warnings as this typically just ends up in a logfile - you should fail if a validation fails).
|
2122
|
+
# The easiest way to raise an appropriate exception is to call the method {Puppet::Util::Errors.fail} with
|
2123
|
+
# the message as an argument.
|
2124
|
+
#
|
2125
|
+
# @yield [ ] a required block called with self set to the instance of a Type class representing a resource.
|
2126
|
+
# @return [void]
|
2127
|
+
# @dsl type
|
2128
|
+
# @api public
|
2129
|
+
#
|
2130
|
+
def self.validate(&block)
|
2131
|
+
define_method(:validate, &block)
|
2132
|
+
end
|
2133
|
+
|
2134
|
+
# @return [String] The file from which this type originates from
|
2135
|
+
attr_accessor :file
|
2136
|
+
|
2137
|
+
# @return [Integer] The line in {#file} from which this type originates from
|
2138
|
+
attr_accessor :line
|
2139
|
+
|
2140
|
+
# @todo what does this mean "this resource" (sounds like this if for an instance of the type, not the meta Type),
|
2141
|
+
# but not sure if this is about the catalog where the meta Type is included)
|
2142
|
+
# @return [??? TODO] The catalog that this resource is stored in.
|
2143
|
+
attr_accessor :catalog
|
2144
|
+
|
2145
|
+
# @return [Boolean] Flag indicating if this type is exported
|
2146
|
+
attr_accessor :exported
|
2147
|
+
|
2148
|
+
# @return [Boolean] Flag indicating if the type is virtual (it should not be).
|
2149
|
+
attr_accessor :virtual
|
2150
|
+
|
2151
|
+
# Creates a log entry with the given message at the log level specified by the parameter `loglevel`
|
2152
|
+
# @return [void]
|
2153
|
+
#
|
2154
|
+
def log(msg)
|
2155
|
+
|
2156
|
+
Puppet::Util::Log.create(
|
2157
|
+
|
2158
|
+
:level => @parameters[:loglevel].value,
|
2159
|
+
:message => msg,
|
2160
|
+
|
2161
|
+
:source => self
|
2162
|
+
)
|
2163
|
+
end
|
2164
|
+
|
2165
|
+
|
2166
|
+
# instance methods related to instance intrinsics
|
2167
|
+
# e.g., initialize and name
|
2168
|
+
|
2169
|
+
public
|
2170
|
+
|
2171
|
+
# @return [Hash] hash of parameters originally defined
|
2172
|
+
# @api private
|
2173
|
+
attr_reader :original_parameters
|
2174
|
+
|
2175
|
+
# Creates an instance of Type from a hash or a {Puppet::Resource}.
|
2176
|
+
# @todo Unclear if this is a new Type or a new instance of a given type (the initialization ends
|
2177
|
+
# with calling validate - which seems like validation of an instance of a given type, not a new
|
2178
|
+
# meta type.
|
2179
|
+
#
|
2180
|
+
# @todo Explain what the Hash and Resource are. There seems to be two different types of
|
2181
|
+
# resources; one that causes the title to be set to resource.title, and one that
|
2182
|
+
# causes the title to be resource.ref ("for components") - what is a component?
|
2183
|
+
#
|
2184
|
+
# @overload initialize(hash)
|
2185
|
+
# @param [Hash] hash
|
2186
|
+
# @raise [Puppet::ResourceError] when the type validation raises
|
2187
|
+
# Puppet::Error or ArgumentError
|
2188
|
+
# @overload initialize(resource)
|
2189
|
+
# @param resource [Puppet:Resource]
|
2190
|
+
# @raise [Puppet::ResourceError] when the type validation raises
|
2191
|
+
# Puppet::Error or ArgumentError
|
2192
|
+
#
|
2193
|
+
def initialize(resource)
|
2194
|
+
resource = self.class.hash2resource(resource) unless resource.is_a?(Puppet::Resource)
|
2195
|
+
|
2196
|
+
# The list of parameter/property instances.
|
2197
|
+
@parameters = {}
|
2198
|
+
|
2199
|
+
# Set the title first, so any failures print correctly.
|
2200
|
+
if resource.type.to_s.downcase.to_sym == self.class.name
|
2201
|
+
self.title = resource.title
|
2202
|
+
else
|
2203
|
+
# This should only ever happen for components
|
2204
|
+
self.title = resource.ref
|
2205
|
+
end
|
2206
|
+
|
2207
|
+
[:file, :line, :catalog, :exported, :virtual].each do |getter|
|
2208
|
+
setter = getter.to_s + "="
|
2209
|
+
if val = resource.send(getter)
|
2210
|
+
self.send(setter, val)
|
2211
|
+
end
|
2212
|
+
end
|
2213
|
+
|
2214
|
+
@tags = resource.tags
|
2215
|
+
|
2216
|
+
@original_parameters = resource.to_hash
|
2217
|
+
|
2218
|
+
set_name(@original_parameters)
|
2219
|
+
|
2220
|
+
set_default(:provider)
|
2221
|
+
|
2222
|
+
set_parameters(@original_parameters)
|
2223
|
+
|
2224
|
+
begin
|
2225
|
+
self.validate if self.respond_to?(:validate)
|
2226
|
+
rescue Puppet::Error, ArgumentError => detail
|
2227
|
+
error = Puppet::ResourceError.new("Validation of #{ref} failed: #{detail}")
|
2228
|
+
adderrorcontext(error, detail)
|
2229
|
+
raise error
|
2230
|
+
end
|
2231
|
+
end
|
2232
|
+
|
2233
|
+
private
|
2234
|
+
|
2235
|
+
# Sets the name of the resource from a hash containing a mapping of `name_var` to value.
|
2236
|
+
# Sets the value of the property/parameter appointed by the `name_var` (if it is defined). The value set is
|
2237
|
+
# given by the corresponding entry in the given hash - e.g. if name_var appoints the name `:path` the value
|
2238
|
+
# of `:path` is set to the value at the key `:path` in the given hash. As a side effect this key/value is then
|
2239
|
+
# removed from the given hash.
|
2240
|
+
#
|
2241
|
+
# @note This method mutates the given hash by removing the entry with a key equal to the value
|
2242
|
+
# returned from name_var!
|
2243
|
+
# @param hash [Hash] a hash of what
|
2244
|
+
# @return [void]
|
2245
|
+
def set_name(hash)
|
2246
|
+
self[name_var] = hash.delete(name_var) if name_var
|
2247
|
+
end
|
2248
|
+
|
2249
|
+
# Sets parameters from the given hash.
|
2250
|
+
# Values are set in _attribute order_ i.e. higher priority attributes before others, otherwise in
|
2251
|
+
# the order they were specified (as opposed to just setting them in the order they happen to appear in
|
2252
|
+
# when iterating over the given hash).
|
2253
|
+
#
|
2254
|
+
# Attributes that are not included in the given hash are set to their default value.
|
2255
|
+
#
|
2256
|
+
# @todo Is this description accurate? Is "ensure" an example of such a higher priority attribute?
|
2257
|
+
# @return [void]
|
2258
|
+
# @raise [Puppet::DevError] when impossible to set the value due to some problem
|
2259
|
+
# @raise [ArgumentError, TypeError, Puppet::Error] when faulty arguments have been passed
|
2260
|
+
#
|
2261
|
+
def set_parameters(hash)
|
2262
|
+
# Use the order provided by allattrs, but add in any
|
2263
|
+
# extra attributes from the resource so we get failures
|
2264
|
+
# on invalid attributes.
|
2265
|
+
no_values = []
|
2266
|
+
(self.class.allattrs + hash.keys).uniq.each do |attr|
|
2267
|
+
begin
|
2268
|
+
# Set any defaults immediately. This is mostly done so
|
2269
|
+
# that the default provider is available for any other
|
2270
|
+
# property validation.
|
2271
|
+
if hash.has_key?(attr)
|
2272
|
+
self[attr] = hash[attr]
|
2273
|
+
else
|
2274
|
+
no_values << attr
|
2275
|
+
end
|
2276
|
+
rescue ArgumentError, Puppet::Error, TypeError
|
2277
|
+
raise
|
2278
|
+
rescue => detail
|
2279
|
+
error = Puppet::DevError.new( "Could not set #{attr} on #{self.class.name}: #{detail}")
|
2280
|
+
error.set_backtrace(detail.backtrace)
|
2281
|
+
raise error
|
2282
|
+
end
|
2283
|
+
end
|
2284
|
+
no_values.each do |attr|
|
2285
|
+
set_default(attr)
|
2286
|
+
end
|
2287
|
+
end
|
2288
|
+
|
2289
|
+
public
|
2290
|
+
|
2291
|
+
# Finishes any outstanding processing.
|
2292
|
+
# This method should be called as a final step in setup,
|
2293
|
+
# to allow the parameters that have associated auto-require needs to be processed.
|
2294
|
+
#
|
2295
|
+
# @todo what is the expected sequence here - who is responsible for calling this? When?
|
2296
|
+
# Is the returned type correct?
|
2297
|
+
# @return [Array<Puppet::Parameter>] the validated list/set of attributes
|
2298
|
+
#
|
2299
|
+
def finish
|
2300
|
+
# Call post_compile hook on every parameter that implements it. This includes all subclasses
|
2301
|
+
# of parameter including, but not limited to, regular parameters, metaparameters, relationship
|
2302
|
+
# parameters, and properties.
|
2303
|
+
eachparameter do |parameter|
|
2304
|
+
parameter.post_compile if parameter.respond_to? :post_compile
|
2305
|
+
end
|
2306
|
+
|
2307
|
+
# Make sure all of our relationships are valid. Again, must be done
|
2308
|
+
# when the entire catalog is instantiated.
|
2309
|
+
self.class.relationship_params.collect do |klass|
|
2310
|
+
if param = @parameters[klass.name]
|
2311
|
+
param.validate_relationship
|
2312
|
+
end
|
2313
|
+
end.flatten.reject { |r| r.nil? }
|
2314
|
+
end
|
2315
|
+
|
2316
|
+
# @comment For now, leave the 'name' method functioning like it used to. Once 'title'
|
2317
|
+
# works everywhere, I'll switch it.
|
2318
|
+
# Returns the resource's name
|
2319
|
+
# @todo There is a comment in source that this is not quite the same as ':title' and that a switch should
|
2320
|
+
# be made...
|
2321
|
+
# @return [String] the name of a resource
|
2322
|
+
def name
|
2323
|
+
self[:name]
|
2324
|
+
end
|
2325
|
+
|
2326
|
+
# Returns the parent of this in the catalog. In case of an erroneous catalog
|
2327
|
+
# where multiple parents have been produced, the first found (non
|
2328
|
+
# deterministic) parent is returned.
|
2329
|
+
# @return [Puppet::Type, nil] the
|
2330
|
+
# containing resource or nil if there is no catalog or no containing
|
2331
|
+
# resource.
|
2332
|
+
def parent
|
2333
|
+
return nil unless catalog
|
2334
|
+
|
2335
|
+
@parent ||=
|
2336
|
+
if parents = catalog.adjacent(self, :direction => :in)
|
2337
|
+
parents.shift
|
2338
|
+
else
|
2339
|
+
nil
|
2340
|
+
end
|
2341
|
+
end
|
2342
|
+
|
2343
|
+
# Returns a reference to this as a string in "Type[name]" format.
|
2344
|
+
# @return [String] a reference to this object on the form 'Type[name]'
|
2345
|
+
#
|
2346
|
+
def ref
|
2347
|
+
# memoizing this is worthwhile ~ 3 percent of calls are the "first time
|
2348
|
+
# around" in an average run of Puppet. --daniel 2012-07-17
|
2349
|
+
@ref ||= "#{self.class.name.to_s.capitalize}[#{self.title}]"
|
2350
|
+
end
|
2351
|
+
|
2352
|
+
# (see self_refresh)
|
2353
|
+
# @todo check that meaningful yardoc is produced - this method delegates to "self.class.self_refresh"
|
2354
|
+
# @return [Boolean] - ??? returns true when ... what?
|
2355
|
+
#
|
2356
|
+
def self_refresh?
|
2357
|
+
self.class.self_refresh
|
2358
|
+
end
|
2359
|
+
|
2360
|
+
# Marks the object as "being purged".
|
2361
|
+
# This method is used by transactions to forbid deletion when there are dependencies.
|
2362
|
+
# @todo what does this mean; "mark that we are purging" (purging what from where). How to use/when?
|
2363
|
+
# Is this internal API in transactions?
|
2364
|
+
# @see purging?
|
2365
|
+
def purging
|
2366
|
+
@purging = true
|
2367
|
+
end
|
2368
|
+
|
2369
|
+
# Returns whether this resource is being purged or not.
|
2370
|
+
# This method is used by transactions to forbid deletion when there are dependencies.
|
2371
|
+
# @return [Boolean] the current "purging" state
|
2372
|
+
#
|
2373
|
+
def purging?
|
2374
|
+
if defined?(@purging)
|
2375
|
+
@purging
|
2376
|
+
else
|
2377
|
+
false
|
2378
|
+
end
|
2379
|
+
end
|
2380
|
+
|
2381
|
+
# Returns the title of this object, or its name if title was not explicetly set.
|
2382
|
+
# If the title is not already set, it will be computed by looking up the {#name_var} and using
|
2383
|
+
# that value as the title.
|
2384
|
+
# @todo it is somewhat confusing that if the name_var is a valid parameter, it is assumed to
|
2385
|
+
# be the name_var called :name, but if it is a property, it uses the name_var.
|
2386
|
+
# It is further confusing as Type in some respects supports multiple namevars.
|
2387
|
+
#
|
2388
|
+
# @return [String] Returns the title of this object, or its name if title was not explicetly set.
|
2389
|
+
# @raise [??? devfail] if title is not set, and name_var can not be found.
|
2390
|
+
def title
|
2391
|
+
unless @title
|
2392
|
+
if self.class.validparameter?(name_var)
|
2393
|
+
@title = self[:name]
|
2394
|
+
elsif self.class.validproperty?(name_var)
|
2395
|
+
@title = self.should(name_var)
|
2396
|
+
else
|
2397
|
+
self.devfail "Could not find namevar #{name_var} for #{self.class.name}"
|
2398
|
+
end
|
2399
|
+
end
|
2400
|
+
|
2401
|
+
@title
|
2402
|
+
end
|
2403
|
+
|
2404
|
+
# Produces a reference to this in reference format.
|
2405
|
+
# @see #ref
|
2406
|
+
#
|
2407
|
+
def to_s
|
2408
|
+
self.ref
|
2409
|
+
end
|
2410
|
+
|
2411
|
+
# Convert this resource type instance to a Puppet::Resource.
|
2412
|
+
# @return [Puppet::Resource] Returns a serializable representation of this resource
|
2413
|
+
#
|
2414
|
+
def to_resource
|
2415
|
+
resource = self.retrieve_resource
|
2416
|
+
resource.tag(*self.tags)
|
2417
|
+
|
2418
|
+
@parameters.each do |name, param|
|
2419
|
+
# Avoid adding each instance name twice
|
2420
|
+
next if param.class.isnamevar? and param.value == self.title
|
2421
|
+
|
2422
|
+
# We've already got property values
|
2423
|
+
next if param.is_a?(Puppet::Property)
|
2424
|
+
resource[name] = param.value
|
2425
|
+
end
|
2426
|
+
|
2427
|
+
resource
|
2428
|
+
end
|
2429
|
+
|
2430
|
+
# @return [Boolean] Returns whether the resource is virtual or not
|
2431
|
+
def virtual?; !!@virtual; end
|
2432
|
+
# @return [Boolean] Returns whether the resource is exported or not
|
2433
|
+
def exported?; !!@exported; end
|
2434
|
+
|
2435
|
+
# @return [Boolean] Returns whether the resource is applicable to `:device`
|
2436
|
+
# Returns true if a resource of this type can be evaluated on a 'network device' kind
|
2437
|
+
# of hosts.
|
2438
|
+
# @api private
|
2439
|
+
def appliable_to_device?
|
2440
|
+
self.class.can_apply_to(:device)
|
2441
|
+
end
|
2442
|
+
|
2443
|
+
# @return [Boolean] Returns whether the resource is applicable to `:host`
|
2444
|
+
# Returns true if a resource of this type can be evaluated on a regular generalized computer (ie not an appliance like a network device)
|
2445
|
+
# @api private
|
2446
|
+
def appliable_to_host?
|
2447
|
+
self.class.can_apply_to(:host)
|
2448
|
+
end
|
2449
|
+
end
|
2450
|
+
end
|
2451
|
+
|
2452
|
+
require 'puppet/provider'
|