1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
# Copyright 2011-2013 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"). You
# may not use this file except in compliance with the License. A copy of
# the License is located at
#
# http://aws.amazon.com/apache2.0/
#
# or in the "license" file accompanying this file. This file is
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.
module AWS
class EC2
# Represents an EC2 key pair.
# @attr_reader [String] fingerprint A SHA-1 digest of the DER encoded
# private key
class KeyPair < Resource
def initialize name, options = {}
@name = name.to_s
@private_key = options[:private_key]
super
end
# @return [String] The name of the key pair.
attr_reader :name
attribute :fingerprint, :from => :key_fingerprint, :static => true
populates_from(:create_key_pair, :import_key_pair) do |resp|
resp if resp.key_name == name
end
populates_from(:describe_key_pairs) do |resp|
resp.key_set.find{|k| k.key_name == name }
end
# @return [Boolean] True if the key pair exists.
def exists?
resp = client.describe_key_pairs(:filters => [
{ :name => "key-name", :values => [name] }
])
!resp.key_set.empty?
end
# Returns the private key. Raises an exception if called
# against an existing key. You can only get the private key
# at the time of creation.
#
# @see KeyPairCollection#import
# @note Only call this method on newly created keys.
# @return [String] An unencrypted PEM encoded RSA private key.
def private_key
unless @private_key
raise 'you can only get the private key for just-created keypairs'
end
@private_key
end
# Deletes this key pair from EC2.
# @return [true]
def delete
client.delete_key_pair(:key_name => name)
true
end
protected
def response_id_method
:key_name
end
protected
def find_in_response(resp)
resp.key_index[name]
end
end
end
end
|