Class: Inspec::PluginCtl
- Inherits:
-
Object
- Object
- Inspec::PluginCtl
- 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
-
#registry ⇒ Object
readonly
Returns the value of attribute registry.
Instance Method Summary collapse
-
#initialize(home = nil) ⇒ PluginCtl
constructor
A new instance of PluginCtl.
- #load(name) ⇒ Object
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.(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 = __dir__ @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
#registry ⇒ Object (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 |