Class: SshKeyPair
Constant Summary
CloudstackCli::Helper::ASYNC_STATES
Instance Attribute Summary
#config
Instance Method Summary
collapse
exit_on_failure?, start
#resolve_account, #resolve_compute_offering, #resolve_disk_offering, #resolve_domain, #resolve_host, #resolve_iso, #resolve_networks, #resolve_project, #resolve_snapshot, #resolve_template, #resolve_virtual_machine, #resolve_zone, #vm_options_to_params
#ask_number, #bootstrap_server, #bootstrap_server_interactive, #create_port_rules, #create_server, #get_server_default_nic, #get_server_fqdn, #get_server_public_ip, #get_ssh_port_forwarding_rule, #print_job_status, #print_options, #run_background_jobs, #update_job_status, #update_jobs, #watch_jobs
Instance Method Details
#create(name) ⇒ Object
25
26
27
28
29
30
31
32
33
34
|
# File 'lib/cloudstack-cli/commands/ssh_key_pair.rb', line 25
def create(name)
resolve_account
resolve_project
options[:name] = name
pair = client.create_ssh_key_pair(options)
say "Name : #{pair['name']}"
say "Fingerprint : #{pair['fingerprint']}"
say "Privatekey:"
say pair['privatekey']
end
|
#delete(name) ⇒ Object
64
65
66
67
68
69
70
71
72
73
74
75
76
|
# File 'lib/cloudstack-cli/commands/ssh_key_pair.rb', line 64
def delete(name)
resolve_account
resolve_project
options[:name] = name
if options[:force] || yes?("Delete ssh key pair #{name}?", :yellow)
if client.delete_ssh_key_pair(options)['success'] == "true"
say("OK", :green)
else
say("Failed", :red)
exit 1
end
end
end
|
#list ⇒ Object
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
# File 'lib/cloudstack-cli/commands/ssh_key_pair.rb', line 7
def list
resolve_account
resolve_project
pairs = client.list_ssh_key_pairs(options)
if pairs.size < 1
say "No ssh key pairs found."
else
table = [["Name", "Fingerprint"]]
pairs.each do |pair|
table << [pair['name'], pair['fingerprint']]
end
print_table table
end
end
|
#register(name) ⇒ Object
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
# File 'lib/cloudstack-cli/commands/ssh_key_pair.rb', line 40
def register(name)
resolve_account
resolve_project
options[:name] = name
if File.exist?(options[:public_key])
public_key = IO.read(options[:public_key])
else
say("Can't open public key #{options[:public_key]}", :red)
exit 1
end
pair = client.register_ssh_key_pair(options)
say "Name : #{pair['name']}"
say "Fingerprint : #{pair['fingerprint']}"
say "Privatekey:"
say pair['privatekey']
rescue => e
say "Failed to register key: #{e.message}", :red
exit 1
end
|