Class: Puppet::Resource::Catalog::Compiler
- Inherits:
-
Indirector::Code
- Object
- Indirector::Terminus
- Indirector::Code
- Puppet::Resource::Catalog::Compiler
- Includes:
- Util, Util::Checksums
- Defined in:
- lib/puppet/indirector/catalog/compiler.rb
Constant Summary
Constants included from Util
Util::AbsolutePathPosix, Util::AbsolutePathWindows, Util::DEFAULT_POSIX_MODE, Util::DEFAULT_WINDOWS_MODE
Constants included from Util::POSIX
Util::POSIX::LOCALE_ENV_VARS, Util::POSIX::USER_ENV_VARS
Constants included from Util::SymbolicFileMode
Util::SymbolicFileMode::SetGIDBit, Util::SymbolicFileMode::SetUIDBit, Util::SymbolicFileMode::StickyBit, Util::SymbolicFileMode::SymbolicMode, Util::SymbolicFileMode::SymbolicSpecialToBit
Constants included from Util::Docs
Instance Attribute Summary collapse
Attributes included from Util::Docs
Instance Method Summary collapse
-
#extract_facts_from_request(request) ⇒ Puppet::Node::Facts
Facts object corresponding to facts in request.
-
#filter(catalog) ⇒ Object
filter-out a catalog to remove exported resources.
-
#find(request) ⇒ Object
Compile a node’s catalog.
-
#initialize ⇒ Compiler
constructor
A new instance of Compiler.
-
#networked? ⇒ Boolean
Is our compiler part of a network, or are we just local?.
- #save_facts_from_request(facts, request) ⇒ Object
Methods included from Util::Checksums
checksum?, checksum_file, checksum_stream, ctime, ctime?, ctime_file, ctime_stream, known_checksum_types, md5, md5?, md5_file, md5_hex_length, md5_stream, md5lite, md5lite?, md5lite_file, md5lite_hex_length, md5lite_stream, mtime, mtime?, mtime_file, mtime_stream, none, none?, none_file, none_stream, sha1, sha1?, sha1_file, sha1_hex_length, sha1_stream, sha1lite, sha1lite?, sha1lite_file, sha1lite_hex_length, sha1lite_stream, sha256, sha256?, sha256_file, sha256_hex_length, sha256_stream, sha256lite, sha256lite?, sha256lite_file, sha256lite_hex_length, sha256lite_stream, sumdata, sumtype
Methods included from Util
absolute_path?, benchmark, chuser, clear_environment, default_env, deterministic_rand, deterministic_rand_int, exit_on_fail, get_env, get_environment, logmethods, merge_environment, path_to_uri, pretty_backtrace, replace_file, safe_posix_fork, set_env, symbolizehash, thinmark, uri_encode, uri_query_encode, uri_to_path, which, withenv, withumask
Methods included from Util::POSIX
#get_posix_field, #gid, #idfield, #methodbyid, #methodbyname, #search_posix_field, #uid
Methods included from Util::SymbolicFileMode
#normalize_symbolic_mode, #symbolic_mode_to_int, #valid_symbolic_mode?
Methods inherited from Indirector::Terminus
abstract_terminus?, #allow_remote_requests?, const2name, #indirection, indirection_name, inherited, mark_as_abstract_terminus, #model, model, #name, name2const, register_terminus_class, terminus_class, terminus_classes, #terminus_type, #validate, #validate_key, #validate_model
Methods included from Util::InstanceLoader
#instance_docs, #instance_hash, #instance_load, #instance_loader, #instance_loading?, #loaded_instance, #loaded_instances
Methods included from Util::Docs
#desc, #dochook, #doctable, #markdown_definitionlist, #markdown_header, #nodoc?, #pad, scrub
Constructor Details
Instance Attribute Details
#code ⇒ Object
15 16 17 |
# File 'lib/puppet/indirector/catalog/compiler.rb', line 15 def code @code end |
Instance Method Details
#extract_facts_from_request(request) ⇒ Puppet::Node::Facts
Returns facts object corresponding to facts in request.
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/puppet/indirector/catalog/compiler.rb', line 20 def extract_facts_from_request(request) return unless text_facts = request.[:facts] unless format = request.[:facts_format] raise ArgumentError, _("Facts but no fact format provided for %{request}") % { request: request.key } end Puppet::Util::Profiler.profile(_("Found facts"), [:compiler, :find_facts]) do facts = text_facts.is_a?(Puppet::Node::Facts) ? text_facts : convert_wire_facts(text_facts, format) unless facts.name == request.key raise Puppet::Error, _("Catalog for %{request} was requested with fact definition for the wrong node (%{fact_name}).") % { request: request.key.inspect, fact_name: facts.name.inspect } end return facts end end |
#filter(catalog) ⇒ Object
filter-out a catalog to remove exported resources
62 63 64 65 |
# File 'lib/puppet/indirector/catalog/compiler.rb', line 62 def filter(catalog) return catalog.filter { |r| r.virtual? } if catalog.respond_to?(:filter) catalog end |
#find(request) ⇒ Object
Compile a node’s catalog.
44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/puppet/indirector/catalog/compiler.rb', line 44 def find(request) facts = extract_facts_from_request(request) save_facts_from_request(facts, request) if !facts.nil? node = node_from_request(facts, request) node.trusted_data = Puppet.lookup(:trusted_information) { Puppet::Context::TrustedInformation.local(node) }.to_h if catalog = compile(node, request.) return catalog else # This shouldn't actually happen; we should either return # a config or raise an exception. return nil end end |
#networked? ⇒ Boolean
Is our compiler part of a network, or are we just local?
74 75 76 |
# File 'lib/puppet/indirector/catalog/compiler.rb', line 74 def networked? Puppet.run_mode.master? end |
#save_facts_from_request(facts, request) ⇒ Object
37 38 39 40 41 |
# File 'lib/puppet/indirector/catalog/compiler.rb', line 37 def save_facts_from_request(facts, request) Puppet::Node::Facts.indirection.save(facts, nil, :environment => request.environment, :transaction_uuid => request.[:transaction_uuid]) end |