Class: ChefDK::Command::Install

Inherits:
Base
  • Object
show all
Includes:
ChefDK::Configurable
Defined in:
lib/chef-dk/command/install.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from ChefDK::Configurable

#chef_config, #chefdk_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

#chefdk_home, #err, #git_bin_dir, #git_windows_bin_dir, #msg, #omnibus_apps_dir, #omnibus_bin_dir, #omnibus_chefdk_location, #omnibus_embedded_bin_dir, #omnibus_env, #omnibus_install?, #omnibus_root, #stderr, #stdout, #system_command, #usr_bin_path, #usr_bin_prefix

Constructor Details

#initialize(*args) ⇒ Install

Returns a new instance of Install.



64
65
66
67
68
69
70
# File 'lib/chef-dk/command/install.rb', line 64

def initialize(*args)
  super
  @ui = UI.new

  @policyfile_relative_path = nil
  @installer = nil
end

Instance Attribute Details

#policyfile_relative_pathObject (readonly)

Returns the value of attribute policyfile_relative_path.



60
61
62
# File 'lib/chef-dk/command/install.rb', line 60

def policyfile_relative_path
  @policyfile_relative_path
end

#uiObject

Returns the value of attribute ui.



62
63
64
# File 'lib/chef-dk/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-dk/command/install.rb', line 109

def apply_params!(params)
  remaining_args = parse_options(params)
  if remaining_args.size > 1
    ui.err(opt_parser)
    return false
  else
    @policyfile_relative_path = remaining_args.first
    true
  end
end

#config_pathObject



95
96
97
# File 'lib/chef-dk/command/install.rb', line 95

def config_path
  config[:config_file]
end

#debug?Boolean

Returns:

  • (Boolean)


91
92
93
# File 'lib/chef-dk/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-dk/command/install.rb', line 99

def handle_error(error)
  ui.err("Error: #{error.message}")
  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

#installerObject



87
88
89
# File 'lib/chef-dk/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-dk/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