summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xec2-init.py8
-rw-r--r--ec2init/CloudConfig.py46
-rw-r--r--ec2init/__init__.py62
3 files changed, 66 insertions, 50 deletions
diff --git a/ec2-init.py b/ec2-init.py
index b483fd5d..4b4bd494 100755
--- a/ec2-init.py
+++ b/ec2-init.py
@@ -12,7 +12,6 @@ def warn(str):
def main():
cloud = ec2init.EC2Init()
- data = None
try:
cloud.get_data_source()
except Exception as e:
@@ -42,13 +41,6 @@ def main():
except:
warn("failed to set defaults\n")
- # set the ssh keys up
- try:
- cloud.sem_and_run("apply_credentials", "once-per-instance",
- cloud.apply_credentials,[],False)
- except:
- warn("applying credentials failed!\n")
-
# enable swap
try:
cloud.sem_and_run("enable_swap", "once-per-instance",
diff --git a/ec2init/CloudConfig.py b/ec2init/CloudConfig.py
index a6393df9..2b628edb 100644
--- a/ec2init/CloudConfig.py
+++ b/ec2init/CloudConfig.py
@@ -19,6 +19,7 @@
import yaml
import re
import ec2init
+import ec2init.util as util
import subprocess
import os
@@ -28,29 +29,19 @@ class CloudConfig():
cfgfile = None
handlers = { }
cfg = None
- old_conffile = '/etc/ec2-init/ec2-config.cfg'
def __init__(self,cfgfile):
- self.cfg = self.get_config_obj(cfgfile)
self.cloud = ec2init.EC2Init()
+ self.cfg = self.get_config_obj(cfgfile)
self.cloud.get_data_source()
self.add_handler('apt-update-upgrade', self.h_apt_update_upgrade)
self.add_handler('config-ssh')
def get_config_obj(self,cfgfile):
- str=""
- # support reading the old ConfigObj format file and turning it
- # into a yaml string
- try:
- f = file(self.old_conffile)
- str+=file.read().replace('=',': ')
- f.close()
- except:
- pass
-
- f = file(cfgfile)
- cfg=yaml.load(str + f.read())
+ f=file(cfgfile)
+ cfg=yaml.load(f.read())
f.close()
+ util.mergedict(cfg,self.cloud.read_cfg)
return(cfg)
def convert_old_config(self):
@@ -134,10 +125,9 @@ class CloudConfig():
self.cloud.sem_and_run(name, freq, handler, [ name, args ])
def h_apt_update_upgrade(self,name,args):
- update = get_cfg_option_bool(self.cfg, 'apt_update', False)
- upgrade = get_cfg_option_bool(self.cfg, 'apt_upgrade', False)
+ update = util.get_cfg_option_bool(self.cfg, 'apt_update', False)
+ upgrade = util.get_cfg_option_bool(self.cfg, 'apt_upgrade', False)
- print "update = %s , upgrade = %s\n" % (update,upgrade)
if update or upgrade:
#retcode = subprocess.call(list)
subprocess.Popen(['apt-get', 'update']).communicate()
@@ -150,7 +140,6 @@ class CloudConfig():
return(True)
def h_config_ssh(self,name,args):
- print "Warning, not doing anything for config %s" % name
if False:
# if there are keys in cloud-config, use them
# TODO: need to get keys from cloud-config if present
@@ -164,8 +153,8 @@ class CloudConfig():
subprocess.call(('sh', '-c', clean_and_gen))
try:
- user = get_cfg_option_str(self.cfg,'user')
- disable_root = get_cfg_option_bool(self.cfg, "disable_root", True)
+ user = util.get_cfg_option_str(self.cfg,'user')
+ disable_root = util.get_cfg_option_bool(self.cfg, "disable_root", True)
keys = self.cloud.get_public_ssh_keys()
apply_credentials(keys,user,disable_root)
except:
@@ -185,23 +174,6 @@ class CloudConfig():
print "Warning, not doing anything for config %s" % name
-def get_cfg_option_bool(yobj, key, default=False):
- if not yobj.has_key(key): return default
- val = yobj[key]
- if yobj[key] in [ True, '1', 'on', 'yes', 'true']:
- return True
- return False
-
-def get_cfg_option_str(yobj, key, default=None):
- if not yobj.has_key(key): return default
- return yobj[key]
-
-def read_conf(fname):
- stream = file(fname)
- conf = yaml.load(stream)
- stream.close()
- return conf
-
def apply_credentials(keys, user, disable_root):
if user:
setup_user_keys(keys, user, '')
diff --git a/ec2init/__init__.py b/ec2init/__init__.py
index a3bab271..f2e9f014 100644
--- a/ec2init/__init__.py
+++ b/ec2init/__init__.py
@@ -26,6 +26,7 @@ import os.path
import errno
import pwd
import subprocess
+import yaml
datadir = '/var/lib/cloud/data'
semdir = '/var/lib/cloud/sem'
@@ -35,14 +36,22 @@ userdata = datadir + '/user-data.txt.i'
user_scripts_dir = datadir + "/scripts"
cloud_config = datadir + '/cloud-config.txt'
data_source_cache = cachedir + '/obj.pkl'
+system_config = '/etc/cloud/cloud.cfg'
cfg_env_name = "CLOUD_CFG"
import DataSourceEc2
import UserDataHandler
+import util
class EC2Init:
- datasource_list = [ DataSourceEc2.DataSourceEc2 ]
+ datasource_map = {
+ "ec2" : DataSourceEc2.DataSourceEc2,
+ }
+ auto_order = [ 'ec2' ]
+
+ cfg = None
part_handlers = { }
+ old_conffile = '/etc/ec2-init/ec2-config.cfg'
def __init__(self):
self.part_handlers = {
@@ -51,7 +60,37 @@ class EC2Init:
'text/upstart-job' : self.handle_upstart_job,
'text/part-handler' : self.handle_handler
}
-
+ self.cfg=self.read_cfg()
+
+ import pprint
+ pprint.pprint(self.cfg)
+
+ def read_cfg(self):
+ if self.cfg:
+ return(self.cfg)
+
+ conf = { }
+ try:
+ stream = file(system_config)
+ conf = yaml.load(stream)
+ stream.close()
+ except:
+ pass
+
+ # support reading the old ConfigObj format file and merging
+ # it into the yaml dictionary
+ try:
+ from configobj import ConfigObj
+ oldcfg = ConfigObj(self.old_conffile)
+ conf = util.mergedict(conf,oldcfg)
+ except:
+ pass
+
+ if not conf.has_key("cloud_type"):
+ conf["cloud_type"]=None
+
+ return(conf)
+
def restore_from_cache(self):
try:
f=open(data_source_cache, "rb")
@@ -69,15 +108,28 @@ class EC2Init:
except:
return False
+ def get_cloud_type(self):
+ pass
+
def get_data_source(self):
if self.restore_from_cache():
return True
- for source in self.datasource_list:
+ dslist=[ ]
+ cfglist=self.cfg['cloud_type']
+ if cfglist == "auto":
+ dslist = self.auto_order
+ elif cfglist:
+ for ds in cfglist.split(','):
+ dslist.append(strip(ds).tolower())
+
+ for ds in dslist:
+ if ds not in self.datasource_map: continue
try:
- s = source()
+ s = self.datasource_map[ds]()
if s.get_data():
self.datasource = s
+ self.datasource_name = ds
return True
except Exception as e:
pass
@@ -226,7 +278,7 @@ class EC2Init:
try:
swaps=self.datasource.getswap_devs()
except:
- print "using fstab"
+ print "using blkid"
process = subprocess.Popen(
['blkid', '-t', 'TYPE=swap', '-o', 'device'],
stdout=subprocess.PIPE)