class Puppet::ResourceApi::Transport::Wrapper

Puppet::ResourceApi::Transport::Wrapper‘ to interface between the Util::NetworkDevice

Attributes

schema[R]
transport[R]

Public Class Methods

deep_symbolize(obj) click to toggle source

From stackoverflow.com/a/11788082/4918

# 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
new(name, url_or_config_or_transport) click to toggle source
# 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

Public Instance Methods

facts() click to toggle source
# 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
method_missing(method_name, *args, &block) click to toggle source
Calls superclass method
# 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
respond_to_missing?(name, _include_private) click to toggle source
Calls superclass method
# 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) click to toggle source
# 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