Class: Inspec::PluginCtl

Inherits:
Object
  • Object
show all
Extended by:
Forwardable
Defined in:
lib/inspec/plugin/v1/plugins.rb

Overview

PLEASE NOTE: The Plugin system is an internal mechanism for connecting inspec components. Its API is currently considered in an alpha state and may change between minor version revisions. A stable plugin API will be released in the future.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(home = nil) ⇒ PluginCtl

Returns a new instance of PluginCtl.



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'lib/inspec/plugin/v1/plugins.rb', line 24

def initialize(home = nil)
  @paths = []

  # load plugins in the same gem installation
  lib_home = File.expand_path(File.join(__FILE__, "..", "..", "..", ".."))
  @paths += Dir[lib_home + "/inspec-*-*/lib/inspec-*rb"]

  # traverse out of inspec-vX.Y.Z/lib/inspec/plugins.rb
  @home = home || File.join(Inspec.config_dir, "plugins")
  @paths += Dir[File.join(@home, "**{,/*/**}", "*.gemspec")]
    .map { |x| File.dirname(x) }
    .map { |x| Dir[File.join(x, "lib", "inspec-*.rb")] }
    .flatten

  # load bundled plugins
  bundled_dir = File.expand_path(File.dirname(__FILE__))
  @paths += Dir[File.join(bundled_dir, "..", "bundles", "inspec-*.rb")].flatten

  # map paths to names
  @registry = Hash[@paths.map do |x|
    [File.basename(x, ".rb"), x]
  end]
end

Instance Attribute Details

#registryObject (readonly)

Returns the value of attribute registry.



21
22
23
# File 'lib/inspec/plugin/v1/plugins.rb', line 21

def registry
  @registry
end

Instance Method Details

#load(name) ⇒ Object



48
49
50
51
52
53
54
55
56
# File 'lib/inspec/plugin/v1/plugins.rb', line 48

def load(name)
  path = @registry[name]
  if path.nil?
    raise "Couldn't find plugin #{name}. Searching in #{@home}"
  end

  # puts "Loading plugin #{name} from #{path}"
  require path
end