Class: Puppet::ResourceApi::Transport::Wrapper
- Inherits:
-
Object
- Object
- Puppet::ResourceApi::Transport::Wrapper
- Defined in:
- lib/puppet/resource_api/transport/wrapper.rb
Overview
Puppet::ResourceApi::Transport::Wrapper` to interface between the Util::NetworkDevice
Instance Attribute Summary collapse
-
#schema ⇒ Object
readonly
Returns the value of attribute schema.
-
#transport ⇒ Object
readonly
Returns the value of attribute transport.
Class Method Summary collapse
Instance Method Summary collapse
- #facts ⇒ Object
-
#initialize(name, url_or_config_or_transport) ⇒ Wrapper
constructor
A new instance of Wrapper.
- #method_missing(method_name, *args, &block) ⇒ Object
- #respond_to_missing?(name, _include_private) ⇒ Boolean
- #transport_class?(name, transport) ⇒ Boolean
Constructor Details
#initialize(name, url_or_config_or_transport) ⇒ Wrapper
Returns a new instance of Wrapper.
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 11 def initialize(name, url_or_config_or_transport) if url_or_config_or_transport.is_a? String url = URI.parse(url_or_config_or_transport) raise "Unexpected url '#{url_or_config_or_transport}' found. Only file:/// URLs for configuration supported at the moment." unless url.scheme == 'file' raise "Trying to load config from '#{url.path}, but file does not exist." if url && !File.exist?(url.path) config = self.class.deep_symbolize(Hocon.load(url.path, syntax: Hocon::ConfigSyntax::HOCON) || {}) elsif url_or_config_or_transport.is_a? Hash config = url_or_config_or_transport elsif transport_class?(name, url_or_config_or_transport) @transport = url_or_config_or_transport end @transport ||= Puppet::ResourceApi::Transport.connect(name, config) @schema = Puppet::ResourceApi::Transport.list[name] end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
43 44 45 46 47 48 49 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 43 def method_missing(method_name, *args, &block) if @transport.respond_to? method_name @transport.send(method_name, *args, &block) else super end end |
Instance Attribute Details
#schema ⇒ Object (readonly)
Returns the value of attribute schema.
9 10 11 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 9 def schema @schema end |
#transport ⇒ Object (readonly)
Returns the value of attribute transport.
9 10 11 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 9 def transport @transport end |
Class Method Details
.deep_symbolize(obj) ⇒ Object
52 53 54 55 56 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 52 def self.deep_symbolize(obj) return obj.each_with_object({}) { |(k, v), memo| memo[k.to_sym] = deep_symbolize(v); } if obj.is_a? Hash return obj.each_with_object([]) { |v, memo| memo << deep_symbolize(v); } if obj.is_a? Array obj end |
Instance Method Details
#facts ⇒ Object
33 34 35 36 37 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 33 def facts context = Puppet::ResourceApi::PuppetContext.new(@schema) # @transport.facts + custom_facts # look into custom facts work by TP @transport.facts(context) end |
#respond_to_missing?(name, _include_private) ⇒ Boolean
39 40 41 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 39 def respond_to_missing?(name, _include_private) (@transport.respond_to? name) || super end |
#transport_class?(name, transport) ⇒ Boolean
27 28 29 30 31 |
# File 'lib/puppet/resource_api/transport/wrapper.rb', line 27 def transport_class?(name, transport) class_name = name.split('_').map { |e| e.capitalize }.join expected = Puppet::Transport.const_get(class_name).to_s expected == transport.class.to_s end |