Class: Chef::Knife::KeyCreate

Inherits:
Object
  • Object
show all
Defined in:
lib/chef/knife/key_create.rb

Overview

Service class for UserKeyCreate and ClientKeyCreate, Implements common functionality of knife [user | org client] key create.

Author:

  • Tyler Cloke

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(actor, actor_field_name, ui, config) ⇒ KeyCreate

Returns a new instance of KeyCreate.



35
36
37
38
39
40
# File 'lib/chef/knife/key_create.rb', line 35

def initialize(actor, actor_field_name, ui, config)
  @actor = actor
  @actor_field_name = actor_field_name
  @ui = ui
  @config = config
end

Instance Attribute Details

#configObject

Returns the value of attribute config.



33
34
35
# File 'lib/chef/knife/key_create.rb', line 33

def config
  @config
end

Instance Method Details

#create_key_from_hash(output) ⇒ Object



72
73
74
# File 'lib/chef/knife/key_create.rb', line 72

def create_key_from_hash(output)
  Chef::Key.from_hash(output).create
end

#display_info(input) ⇒ Object



58
59
60
# File 'lib/chef/knife/key_create.rb', line 58

def display_info(input)
  @ui.info(input)
end

#display_private_key(private_key) ⇒ Object



62
63
64
# File 'lib/chef/knife/key_create.rb', line 62

def display_private_key(private_key)
  @ui.msg(private_key)
end

#edit_data(key) ⇒ Object



50
51
52
# File 'lib/chef/knife/key_create.rb', line 50

def edit_data(key)
  @ui.edit_data(key)
end

#edit_hash(key) ⇒ Object



54
55
56
# File 'lib/chef/knife/key_create.rb', line 54

def edit_hash(key)
  @ui.edit_hash(key)
end

#output_private_key_to_file(private_key) ⇒ Object



66
67
68
69
70
# File 'lib/chef/knife/key_create.rb', line 66

def output_private_key_to_file(private_key)
  File.open(@config[:file], "w") do |f|
    f.print(private_key)
  end
end

#public_key_or_key_name_error_msgObject



42
43
44
45
46
47
48
# File 'lib/chef/knife/key_create.rb', line 42

def public_key_or_key_name_error_msg
  <<~EOS
    You must pass either --public-key or --key-name, or both.
    If you only pass --public-key, a key name will be generated from the fingerprint of your key.
    If you only pass --key-name, a key pair will be generated by the server.
  EOS
end

#runObject



76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
# File 'lib/chef/knife/key_create.rb', line 76

def run
  key = Chef::Key.new(@actor, @actor_field_name)
  if !@config[:public_key] && !@config[:key_name]
    raise Chef::Exceptions::KeyCommandInputError, public_key_or_key_name_error_msg
  elsif !@config[:public_key]
    key.create_key(true)
  end

  if @config[:public_key]
    key.public_key(File.read(File.expand_path(@config[:public_key])))
  end

  if @config[:key_name]
    key.name(@config[:key_name])
  end

  if @config[:expiration_date]
    key.expiration_date(@config[:expiration_date])
  else
    key.expiration_date("infinity")
  end

  output = edit_hash(key)
  key = create_key_from_hash(output)

  display_info("Created key: #{key.name}")
  if key.private_key
    if @config[:file]
      output_private_key_to_file(key.private_key)
    else
      display_private_key(key.private_key)
    end
  end
end