Index: third_party/gsutil/boto/boto/ec2/keypair.py |
diff --git a/third_party/gsutil/boto/boto/ec2/keypair.py b/third_party/gsutil/boto/boto/ec2/keypair.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..65c95908b0d5cc129c1dac4fcab23b1333a9591b |
--- /dev/null |
+++ b/third_party/gsutil/boto/boto/ec2/keypair.py |
@@ -0,0 +1,113 @@ |
+# Copyright (c) 2006,2007 Mitch Garnaat http://garnaat.org/ |
+# |
+# Permission is hereby granted, free of charge, to any person obtaining a |
+# copy of this software and associated documentation files (the |
+# "Software"), to deal in the Software without restriction, including |
+# without limitation the rights to use, copy, modify, merge, publish, dis- |
+# tribute, sublicense, and/or sell copies of the Software, and to permit |
+# persons to whom the Software is furnished to do so, subject to the fol- |
+# lowing conditions: |
+# |
+# The above copyright notice and this permission notice shall be included |
+# in all copies or substantial portions of the Software. |
+# |
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
+# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- |
+# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT |
+# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
+# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
+# IN THE SOFTWARE. |
+ |
+""" |
+Represents an EC2 Keypair |
+""" |
+ |
+import os |
+from boto.ec2.ec2object import EC2Object |
+from boto.exception import BotoClientError |
+ |
+class KeyPair(EC2Object): |
+ |
+ def __init__(self, connection=None): |
+ EC2Object.__init__(self, connection) |
+ self.name = None |
+ self.fingerprint = None |
+ self.material = None |
+ |
+ def __repr__(self): |
+ return 'KeyPair:%s' % self.name |
+ |
+ def endElement(self, name, value, connection): |
+ if name == 'keyName': |
+ self.name = value |
+ elif name == 'keyFingerprint': |
+ self.fingerprint = value |
+ elif name == 'keyMaterial': |
+ self.material = value |
+ else: |
+ setattr(self, name, value) |
+ |
+ def delete(self): |
+ """ |
+ Delete the KeyPair. |
+ |
+ :rtype: bool |
+ :return: True if successful, otherwise False. |
+ """ |
+ return self.connection.delete_key_pair(self.name) |
+ |
+ def save(self, directory_path): |
+ """ |
+ Save the material (the unencrypted PEM encoded RSA private key) |
+ of a newly created KeyPair to a local file. |
+ |
+ :type directory_path: string |
+ :param directory_path: The fully qualified path to the directory |
+ in which the keypair will be saved. The |
+ keypair file will be named using the name |
+ of the keypair as the base name and .pem |
+ for the file extension. If a file of that |
+ name already exists in the directory, an |
+ exception will be raised and the old file |
+ will not be overwritten. |
+ |
+ :rtype: bool |
+ :return: True if successful. |
+ """ |
+ if self.material: |
+ directory_path = os.path.expanduser(directory_path) |
+ file_path = os.path.join(directory_path, '%s.pem' % self.name) |
+ if os.path.exists(file_path): |
+ raise BotoClientError('%s already exists, it will not be overwritten' % file_path) |
+ fp = open(file_path, 'wb') |
+ fp.write(self.material) |
+ fp.close() |
+ os.chmod(file_path, 0600) |
+ return True |
+ else: |
+ raise BotoClientError('KeyPair contains no material') |
+ |
+ def copy_to_region(self, region): |
+ """ |
+ Create a new key pair of the same new in another region. |
+ Note that the new key pair will use a different ssh |
+ cert than the this key pair. After doing the copy, |
+ you will need to save the material associated with the |
+ new key pair (use the save method) to a local file. |
+ |
+ :type region: :class:`boto.ec2.regioninfo.RegionInfo` |
+ :param region: The region to which this security group will be copied. |
+ |
+ :rtype: :class:`boto.ec2.keypair.KeyPair` |
+ :return: The new key pair |
+ """ |
+ if region.name == self.region: |
+ raise BotoClientError('Unable to copy to the same Region') |
+ conn_params = self.connection.get_params() |
+ rconn = region.connect(**conn_params) |
+ kp = rconn.create_key_pair(self.name) |
+ return kp |
+ |
+ |
+ |