summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ec2init/__init__.py23
1 files changed, 15 insertions, 8 deletions
diff --git a/ec2init/__init__.py b/ec2init/__init__.py
index e75e6cbe..729e3a48 100644
--- a/ec2init/__init__.py
+++ b/ec2init/__init__.py
@@ -17,24 +17,30 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
-from configobj import ConfigObj
import os
import socket
+import urllib2
+from configobj import ConfigObj
import boto.utils
class EC2Init():
api_ver = '2008-02-01'
- filename = '/etc/ec2-init/ec2-config.cfg'
+ conffile = '/etc/ec2-init/ec2-config.cfg'
def __init__(self):
self.meta_data_base_url = 'http://169.254.169.254/%s/meta-data' % self.api_ver
self.user_data_base_url = 'http://169.254.169.254/%s/user-data' % self.api_ver
- self.config = ConfigObj(filename)
- self.wait_for_metadata_service()
- bailout_command = self.get_cfg_option_str('bailout_command')
- if bailout_command:
- os.system(bailout_command)
+ self.config = ConfigObj(self.conffile)
+
+ def wait_or_bail(self):
+ if self.wait_for_metadata_service():
+ return True
+ else:
+ bailout_command = self.get_cfg_option_str('bailout_command')
+ if bailout_command:
+ os.system(bailout_command)
+ return False
def get_cfg_option_bool(self, key):
val = self.config[key]
@@ -46,7 +52,8 @@ class EC2Init():
return config[key]
def get_ssh_keys(self):
- data = urllib.urlopen('%s/public-keys/' % self.meta_data_base_url).read()
+ conn = urllib2.urlopen('%s/public-keys/' % self.meta_data_base_url)
+ data = conn.read()
keyids = [line.split('=')[0] for line in data.split('\n')]
return [urllib.urlopen('%s/public-keys/%d/openssh-key' % (self.meta_data_base_url, int(keyid))).read().rstrip() for keyid in keyids]