2010-10-04 17:02:08 -04:00
|
|
|
require 'fog/core/model'
|
2010-03-16 18:46:21 -04:00
|
|
|
|
2009-08-13 01:33:35 -04:00
|
|
|
module Fog
|
2011-06-16 19:28:54 -04:00
|
|
|
module Compute
|
|
|
|
class AWS
|
2009-08-13 01:33:35 -04:00
|
|
|
|
|
|
|
class KeyPair < Fog::Model
|
|
|
|
|
2010-09-07 14:30:02 -04:00
|
|
|
identity :name, :aliases => 'keyName'
|
2009-10-24 01:23:55 -04:00
|
|
|
|
2010-09-07 14:30:02 -04:00
|
|
|
attribute :fingerprint, :aliases => 'keyFingerprint'
|
2010-09-22 15:06:25 -04:00
|
|
|
attribute :private_key, :aliases => 'keyMaterial'
|
|
|
|
|
|
|
|
attr_accessor :public_key
|
2009-08-13 01:33:35 -04:00
|
|
|
|
2009-09-20 12:21:03 -04:00
|
|
|
def destroy
|
2009-11-21 16:56:39 -05:00
|
|
|
requires :name
|
|
|
|
|
2012-12-22 18:31:31 -05:00
|
|
|
service.delete_key_pair(name)
|
2009-09-05 23:50:40 -04:00
|
|
|
true
|
2009-08-13 01:33:35 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def save
|
2009-11-21 16:56:39 -05:00
|
|
|
requires :name
|
|
|
|
|
2010-09-22 15:06:25 -04:00
|
|
|
data = if public_key
|
2012-12-22 18:31:31 -05:00
|
|
|
service.import_key_pair(name, public_key).body
|
2010-09-22 15:06:25 -04:00
|
|
|
else
|
2012-12-22 18:31:31 -05:00
|
|
|
service.create_key_pair(name).body
|
2010-09-22 15:06:25 -04:00
|
|
|
end
|
2009-08-14 12:19:40 -04:00
|
|
|
new_attributes = data.reject {|key,value| !['keyFingerprint', 'keyMaterial', 'keyName'].include?(key)}
|
2009-09-28 00:31:15 -04:00
|
|
|
merge_attributes(new_attributes)
|
2009-09-05 23:50:40 -04:00
|
|
|
true
|
2011-04-02 12:06:22 -04:00
|
|
|
|
2009-08-13 01:33:35 -04:00
|
|
|
end
|
|
|
|
|
2011-03-31 04:09:53 -04:00
|
|
|
def write(path="#{ENV['HOME']}/.ssh/fog_#{Fog.credential.to_s}_#{name}.pem")
|
2012-12-22 18:31:31 -05:00
|
|
|
|
2011-03-31 03:31:33 -04:00
|
|
|
if writable?
|
|
|
|
split_private_key = private_key.split(/\n/)
|
2011-04-02 12:06:22 -04:00
|
|
|
File.open(path, "w") do |f|
|
|
|
|
split_private_key.each {|line| f.puts line}
|
|
|
|
f.chmod 0600
|
|
|
|
end
|
2011-03-31 03:31:33 -04:00
|
|
|
"Key file built: #{path}"
|
|
|
|
else
|
|
|
|
"Invalid private key"
|
|
|
|
end
|
|
|
|
end
|
2010-09-22 15:06:25 -04:00
|
|
|
|
2011-03-31 03:48:34 -04:00
|
|
|
def writable?
|
2011-04-02 12:06:22 -04:00
|
|
|
!!(private_key && ENV.has_key?('HOME'))
|
2011-03-31 03:48:34 -04:00
|
|
|
end
|
|
|
|
|
2009-08-13 01:33:35 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|