Class: Chef::Knife::Bootstrap::ChefVaultHandler
- Inherits:
-
Object
- Object
- Chef::Knife::Bootstrap::ChefVaultHandler
- Defined in:
- lib/chef/knife/bootstrap/chef_vault_handler.rb
Instance Attribute Summary collapse
-
#client ⇒ Chef::ApiClient
readonly
Vault client.
-
#knife_config ⇒ Hash
Knife merged config, typically @config.
-
#ui ⇒ Chef::Knife::UI
Ui object for output.
Instance Method Summary collapse
-
#doing_chef_vault? ⇒ Boolean
If we’ve got chef vault options to act on or not.
-
#initialize(knife_config: {}, ui: nil) ⇒ ChefVaultHandler
constructor
A new instance of ChefVaultHandler.
-
#load_chef_bootstrap_vault_item(vault, item) ⇒ Object
Hook to stub out ChefVault.
-
#run(client) ⇒ Object
Updates the chef vault items for the newly created client.
-
#update_bootstrap_vault_json! ⇒ Object
Iterate through all the vault items to update.
Constructor Details
#initialize(knife_config: {}, ui: nil) ⇒ ChefVaultHandler
Returns a new instance of ChefVaultHandler.
36 37 38 39 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 36 def initialize(knife_config: {}, ui: nil) @knife_config = knife_config @ui = ui end |
Instance Attribute Details
#client ⇒ Chef::ApiClient (readonly)
Returns vault client.
32 33 34 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 32 def client @client end |
#knife_config ⇒ Hash
Returns knife merged config, typically @config.
26 27 28 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 26 def knife_config @knife_config end |
#ui ⇒ Chef::Knife::UI
Returns ui object for output.
29 30 31 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 29 def ui @ui end |
Instance Method Details
#doing_chef_vault? ⇒ Boolean
Returns if we’ve got chef vault options to act on or not.
71 72 73 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 71 def doing_chef_vault? !!(bootstrap_vault_json || bootstrap_vault_file || bootstrap_vault_item) end |
#load_chef_bootstrap_vault_item(vault, item) ⇒ Object
Hook to stub out ChefVault
135 136 137 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 135 def load_chef_bootstrap_vault_item(vault, item) ChefVault::Item.load(vault, item) end |
#run(client) ⇒ Object
Updates the chef vault items for the newly created client.
44 45 46 47 48 49 50 51 52 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 44 def run(client) return unless doing_chef_vault? sanity_check @client = client update_bootstrap_vault_json! end |
#update_bootstrap_vault_json! ⇒ Object
Iterate through all the vault items to update. Items may be either a String or an Array of Strings:
"vault1": "item",
"vault2": [ "item1", "item2", "item2" ]
62 63 64 65 66 67 68 |
# File 'lib/chef/knife/bootstrap/chef_vault_handler.rb', line 62 def update_bootstrap_vault_json! vault_json.each do |vault, items| [ items ].flatten.each do |item| update_vault(vault, item) end end end |