diff options
author | Scott Moser <smoser@ubuntu.com> | 2010-01-26 16:40:10 -0500 |
---|---|---|
committer | Scott Moser <smoser@ubuntu.com> | 2010-01-26 16:40:10 -0500 |
commit | 63ba097865e1d038d82a7fa1d6efd282784677f5 (patch) | |
tree | 1616db14a425c16c1b52d8cda6442b6eef52c536 /ec2init | |
parent | af394388ff0985b4b407ed4faeb105395655d102 (diff) | |
download | vyos-cloud-init-63ba097865e1d038d82a7fa1d6efd282784677f5.tar.gz vyos-cloud-init-63ba097865e1d038d82a7fa1d6efd282784677f5.zip |
move writing sources.list to CloudConfig. add 'apt_preserve_sources_list'
Move the writing of sources.list to CloudConfig. This way we have
access to the cloud-config user data. Then, allow the user
to specify the archive mirror using 'apt_mirror' key.
Now, if specified in cloud-config, that is used, otherwise, we
get one from the DataSource.
One other change here is adding 'apt_preserve_sources_list'. If set to
true, then overwriting of the sources.list with the selected mirror
will not be done.
Diffstat (limited to 'ec2init')
-rw-r--r-- | ec2init/CloudConfig.py | 15 | ||||
-rw-r--r-- | ec2init/__init__.py | 9 | ||||
-rw-r--r-- | ec2init/util.py | 8 |
3 files changed, 32 insertions, 0 deletions
diff --git a/ec2init/CloudConfig.py b/ec2init/CloudConfig.py index 6c661260..51618943 100644 --- a/ec2init/CloudConfig.py +++ b/ec2init/CloudConfig.py @@ -99,6 +99,13 @@ class CloudConfig(): update = util.get_cfg_option_bool(self.cfg, 'apt_update', False) upgrade = util.get_cfg_option_bool(self.cfg, 'apt_upgrade', False) + if not util.get_cfg_option_bool(self.cfg, \ + 'apt_preserve_sources_list', False): + if self.cfg.has_key("apt_mirror"): + mirror = self.cfg["apt_mirror"] + else: + mirror = self.cloud.get_mirror() + generate_sources_list(mirror) # process 'apt_sources' if self.cfg.has_key('apt_sources'): @@ -277,3 +284,11 @@ def add_sources(srclist): elst.append([source, "failed write to file %s" % ent['filename']]) return(elst) + + +def generate_sources_list(mirror): + stdout, stderr = subprocess.Popen(['lsb_release', '-cs'], stdout=subprocess.PIPE).communicate() + codename = stdout.strip() + + util.render_to_file('sources.list', '/etc/apt/sources.list', \ + { 'mirror' : mirror, 'codename' : codename }) diff --git a/ec2init/__init__.py b/ec2init/__init__.py index f89839ab..c4923f1b 100644 --- a/ec2init/__init__.py +++ b/ec2init/__init__.py @@ -260,6 +260,15 @@ class EC2Init: f=open(cloud_config, "wb") f.write(self.cloud_config_str) f.close() + + ## this could merge the cloud config with the system config + ## for now, not doing this as it seems somewhat circular + ## as CloudConfig does that also, merging it with this cfg + ## + # ccfg = yaml.load(self.cloud_config_str) + # if ccfg is None: ccfg = { } + # self.cfg = util.mergedict(ccfg, self.cfg) + return self.cloud_config_str+="\n#%s\n%s" % (filename,payload) diff --git a/ec2init/util.py b/ec2init/util.py index ece5755a..403832ff 100644 --- a/ec2init/util.py +++ b/ec2init/util.py @@ -2,6 +2,7 @@ import yaml import os import errno import subprocess +from Cheetah.Template import Template def read_conf(fname): stream = file(fname) @@ -69,3 +70,10 @@ def subp(args, input=None): if sp.returncode is not 0: raise subprocess.CalledProcessError(sp.returncode,args) return(out,err) + +def render_to_file(template, outfile, searchList): + t = Template(file='/etc/ec2-init/templates/%s.tmpl' % template, searchList=[searchList]) + f = open(outfile, 'w') + f.write(t.respond()) + f.close() + |