Class: ChefCLI::Command::Install
- Includes:
- ChefCLI::Configurable
- Defined in:
- lib/chef-cli/command/install.rb
Instance Attribute Summary collapse
-
#policyfile_relative_path ⇒ Object
readonly
Returns the value of attribute policyfile_relative_path.
-
#ui ⇒ Object
Returns the value of attribute ui.
Instance Method Summary collapse
- #apply_params!(params) ⇒ Object
- #config_path ⇒ Object
- #debug? ⇒ Boolean
- #handle_error(error) ⇒ Object
-
#initialize(*args) ⇒ Install
constructor
A new instance of Install.
- #installer ⇒ Object
- #run(params = []) ⇒ Object
Methods included from ChefCLI::Configurable
#chef_config, #chefcli_config, #config_loader, #default_chef_server_http_client, #generator_config, #knife_config, #reset_config!
Methods inherited from Base
#check_license_acceptance, #needs_help?, #needs_version?, #run_with_default_options
Methods included from Helpers
#err, #git_bin_dir, #git_windows_bin_dir, #msg, #omnibus_bin_dir, #omnibus_embedded_bin_dir, #omnibus_env, #omnibus_expand_path, #omnibus_install?, #omnibus_root, #package_home, #stderr, #stdout, #system_command, #usr_bin_path, #usr_bin_prefix
Constructor Details
Instance Attribute Details
#policyfile_relative_path ⇒ Object (readonly)
Returns the value of attribute policyfile_relative_path.
60 61 62 |
# File 'lib/chef-cli/command/install.rb', line 60 def policyfile_relative_path @policyfile_relative_path end |
#ui ⇒ Object
Returns the value of attribute ui.
62 63 64 |
# File 'lib/chef-cli/command/install.rb', line 62 def ui @ui end |
Instance Method Details
#apply_params!(params) ⇒ Object
109 110 111 112 113 114 115 116 117 118 |
# File 'lib/chef-cli/command/install.rb', line 109 def apply_params!(params) remaining_args = (params) if remaining_args.size > 1 ui.err(opt_parser) false else @policyfile_relative_path = remaining_args.first true end end |
#config_path ⇒ Object
95 96 97 |
# File 'lib/chef-cli/command/install.rb', line 95 def config_path config[:config_file] end |
#debug? ⇒ Boolean
91 92 93 |
# File 'lib/chef-cli/command/install.rb', line 91 def debug? !!config[:debug] end |
#handle_error(error) ⇒ Object
99 100 101 102 103 104 105 106 107 |
# File 'lib/chef-cli/command/install.rb', line 99 def handle_error(error) ui.err("Error: #{error.}") if error.respond_to?(:reason) ui.err("Reason: #{error.reason}") ui.err("") ui.err(error.extended_error_info) if debug? ui.err(error.cause.backtrace.join("\n")) if debug? end end |
#installer ⇒ Object
87 88 89 |
# File 'lib/chef-cli/command/install.rb', line 87 def installer @installer ||= PolicyfileServices::Install.new(policyfile: policyfile_relative_path, ui: ui, root_dir: Dir.pwd, config: chef_config) end |
#run(params = []) ⇒ Object
72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/chef-cli/command/install.rb', line 72 def run(params = []) return 1 unless apply_params!(params) # Force config file to be loaded. We don't use the configuration # directly, but the user may have SSL configuration options that they # need to talk to a private supermarket (e.g., trusted_certs or # ssl_verify_mode) chef_config installer.run 0 rescue PolicyfileServiceError => e handle_error(e) 1 end |