diff options
-rw-r--r-- | ec2init/CloudConfig.py | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/ec2init/CloudConfig.py b/ec2init/CloudConfig.py index 2b628edb..8a889a2b 100644 --- a/ec2init/CloudConfig.py +++ b/ec2init/CloudConfig.py @@ -69,14 +69,6 @@ class CloudConfig(): def get_handler_info(self, name): return(self.handlers[name]['handler'], self.handlers[name]['freq']) - def check_for_updates(self): - value = self.cfg['apt_update'] - return value - - def check_for_upgrade(self): - value = self.cfg['apt_upgrade'] - return value - def parse_ssh_keys(self): disableRoot = self.cfg['disable_root'] if disableRoot == 'true': @@ -127,16 +119,28 @@ class CloudConfig(): def h_apt_update_upgrade(self,name,args): update = util.get_cfg_option_bool(self.cfg, 'apt_update', False) upgrade = util.get_cfg_option_bool(self.cfg, 'apt_upgrade', False) + + pkglist = [] + if 'packages' in self.cfg: + if isinstance(self.cfg['packages'],list): + pkglist = self.cfg['packages'] + else: pkglist.append(self.cfg['packages']) - if update or upgrade: + if update or upgrade or pkglist: #retcode = subprocess.call(list) subprocess.Popen(['apt-get', 'update']).communicate() + e=os.environ.copy() + e['DEBIAN_FRONTEND']='noninteractive' + if upgrade: - e=os.environ.copy() - e['DEBIAN_FRONTEND']='noninteractive' subprocess.Popen(['apt-get', 'upgrade', '--assume-yes'], env=e).communicate() + if pkglist: + cmd=['apt-get', 'install', '--assume-yes'] + cmd.extend(pkglist) + subprocess.Popen(cmd, env=e).communicate() + return(True) def h_config_ssh(self,name,args): |