refactor the config class and jobs to run through cloud-init-cfg
At this point, the following should be functional: cloud-init-cfg apt-update-upgrade
This commit is contained in:
parent
0c622a35e0
commit
56f5e69c7a
40
cloud-init-cfg.py
Executable file
40
cloud-init-cfg.py
Executable file
@ -0,0 +1,40 @@
|
||||
#!/usr/bin/python
|
||||
|
||||
import sys
|
||||
import ec2init
|
||||
|
||||
def Usage(out = sys.stdout):
|
||||
out.write("Usage: %s name\n" % sys.argv[0])
|
||||
|
||||
def main():
|
||||
# expect to be called with
|
||||
# name freq [ args ]
|
||||
if len(sys.argv) < 2:
|
||||
Usage(sys.stderr)
|
||||
sys.exit(1)
|
||||
|
||||
name=sys.argv[1]
|
||||
run_args=sys.argv[2:]
|
||||
|
||||
import ec2init.CloudConfig
|
||||
import os
|
||||
|
||||
cfg_path = ec2init.cloud_config
|
||||
cfg_env_name = ec2init.cfg_env_name
|
||||
if os.environ.has_key(cfg_env_name):
|
||||
cfg_path = os.environ[cfg_env_name]
|
||||
|
||||
cc = ec2init.CloudConfig.CloudConfig(cfg_path)
|
||||
|
||||
try:
|
||||
cc.handle(name,run_args)
|
||||
except:
|
||||
import traceback
|
||||
traceback.print_exc(file=sys.stderr)
|
||||
sys.stderr.write("config handling of %s failed\n" % name)
|
||||
sys.exit(1)
|
||||
|
||||
sys.exit(0)
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
155
ec2init/CloudConfig.py
Normal file
155
ec2init/CloudConfig.py
Normal file
@ -0,0 +1,155 @@
|
||||
#
|
||||
# Common code for the EC2 configuration files in Ubuntu
|
||||
# Copyright (C) 2008-2010 Canonical Ltd.
|
||||
#
|
||||
# Author: Chuck Short <chuck.short@canonical.com>
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License version 3, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
import yaml
|
||||
import re
|
||||
import ec2init
|
||||
import subprocess
|
||||
import os
|
||||
|
||||
per_instance="once-per-instance"
|
||||
|
||||
class CloudConfig():
|
||||
cfgfile = None
|
||||
handlers = { }
|
||||
cfg = None
|
||||
|
||||
def __init__(self,cfgfile):
|
||||
print "reading %s" % cfgfile
|
||||
self.cfg=read_conf(cfgfile)
|
||||
import pprint; pprint.pprint(self.cfg)
|
||||
self.cloud = ec2init.EC2Init()
|
||||
self.cloud.get_data_source()
|
||||
self.add_handler('apt-update-upgrade', self.h_apt_update_upgrade)
|
||||
self.add_handler('config-ssh')
|
||||
|
||||
def add_handler(self, name, handler=None, freq=None):
|
||||
if handler is None:
|
||||
try:
|
||||
handler=getattr(self,'h_%s' % name.replace('-','_'))
|
||||
except:
|
||||
raise Exception("Unknown hander for name %s" %name)
|
||||
if freq is None:
|
||||
freq = per_instance
|
||||
|
||||
self.handlers[name]= { 'handler': handler, 'freq': freq }
|
||||
|
||||
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':
|
||||
value = 'disabled_root'
|
||||
return value
|
||||
else:
|
||||
ec2Key = self.cfg['ec2_fetch_key']
|
||||
if ec2Key != 'none':
|
||||
value = 'default_key'
|
||||
return value
|
||||
else:
|
||||
return ec2Key
|
||||
|
||||
def add_ppa(self):
|
||||
#value = self.cfg['apt_sources']
|
||||
for ent in self.cfg['apt_sources']:
|
||||
ppa = ent['source']
|
||||
where = ppa.find('ppa:')
|
||||
if where != -1:
|
||||
return ppa
|
||||
|
||||
def add_custom_repo(self):
|
||||
sources = []
|
||||
value = self.cfg['apt_sources']
|
||||
for ent in self.cfg['apt_sources']:
|
||||
if ent.has_key('keyserver'):
|
||||
keyserver = ent['keyserver']
|
||||
if ent.has_key('keyid'):
|
||||
keyid = ent['keyid']
|
||||
if ent.has_key('filename'):
|
||||
filename = ent['filename']
|
||||
source = ent['source']
|
||||
if source.startswith("deb"):
|
||||
sources.append(source)
|
||||
|
||||
return (keyserver,sources,keyid,filename)
|
||||
|
||||
def handle(self, name, args):
|
||||
handler = None
|
||||
freq = None
|
||||
try:
|
||||
(handler, freq) = self.get_handler_info(name)
|
||||
except:
|
||||
raise Exception("Unknown config key %s\n", name)
|
||||
|
||||
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)
|
||||
|
||||
print "update = %s , upgrade = %s\n" % (update,upgrade)
|
||||
if update or upgrade:
|
||||
#retcode = subprocess.call(list)
|
||||
subprocess.Popen(['apt-get', 'update']).communicate()
|
||||
|
||||
if upgrade:
|
||||
e=os.environ.copy()
|
||||
e['DEBIAN_FRONTEND']='noninteractive'
|
||||
subprocess.Popen(['apt-get', 'upgrade', '--assume-yes'], env=e).communicate()
|
||||
|
||||
return(True)
|
||||
|
||||
def h_config_ssh(self,name,args):
|
||||
print "Warning, not doing anything for config %s" % name
|
||||
|
||||
def h_config_ec2_ebs_mounts(self,name,args):
|
||||
print "Warning, not doing anything for config %s" % name
|
||||
|
||||
def h_config_setup_raid(self,name,args):
|
||||
print "Warning, not doing anything for config %s" % name
|
||||
|
||||
def h_config_runurl(self,name,args):
|
||||
print "Warning, not doing anything for config %s" % name
|
||||
|
||||
|
||||
def get_cfg_option_bool(yobj, key, default=False):
|
||||
print "searching for %s" % key
|
||||
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
|
@ -1,92 +0,0 @@
|
||||
#
|
||||
# Common code for the EC2 configuration files in Ubuntu
|
||||
# Copyright (C) 2008-2010 Canonical Ltd.
|
||||
#
|
||||
# Author: Chuck Short <chuck.short@canonical.com>
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License version 3, as
|
||||
# published by the Free Software Foundation.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
#
|
||||
import yaml
|
||||
import re
|
||||
|
||||
class EC2Config():
|
||||
def read_conf(self, ec2Config):
|
||||
#stream = file('/tmp/ec2.yaml')
|
||||
ec2Config = yaml.load(stream)
|
||||
stream.close()
|
||||
return ec2Config
|
||||
|
||||
def check_for_updates(self):
|
||||
#stream = file('/tmp/ec2.yaml')
|
||||
ec2Config = yaml.load(stream)
|
||||
stream.close()
|
||||
|
||||
value = ec2Config['apt_update']
|
||||
return value
|
||||
|
||||
def check_for_upgrade(self):
|
||||
#stream = file('/tmp/ec2.yaml')
|
||||
ec2Config = yaml.load(stream)
|
||||
stream.close()
|
||||
|
||||
value = ec2Config['apt_upgrade']
|
||||
return value
|
||||
|
||||
def parse_ssh_keys(self):
|
||||
#stream = file('/tmp/ec2.yaml')
|
||||
ec2Config = yaml.load(stream)
|
||||
stream.close()
|
||||
|
||||
disableRoot = ec2Config['disable_root']
|
||||
if disableRoot == 'true':
|
||||
value = 'disabled_root'
|
||||
return value
|
||||
else:
|
||||
ec2Key = ec2Config['ec2_fetch_key']
|
||||
if ec2Key != 'none':
|
||||
value = 'default_key'
|
||||
return value
|
||||
else:
|
||||
return ec2Key
|
||||
|
||||
def add_ppa(self):
|
||||
stream = file('/tmp/ec2.yaml')
|
||||
ec2Config = yaml.load(stream)
|
||||
stream.close()
|
||||
|
||||
value = ec2Config['apt_sources']
|
||||
for ent in ec2Config['apt_sources']:
|
||||
ppa = ent['source']
|
||||
where = ppa.find('ppa:')
|
||||
if where != -1:
|
||||
return ppa
|
||||
|
||||
def add_custom_repo(self):
|
||||
stream = file('/tmp/ec2.yaml')
|
||||
ec2Config = yaml.load(stream)
|
||||
stream.close()
|
||||
|
||||
sources = []
|
||||
value = ec2Config['apt_sources']
|
||||
for ent in ec2Config['apt_sources']:
|
||||
if ent.has_key('keyserver'):
|
||||
keyserver = ent['keyserver']
|
||||
if ent.has_key('keyid'):
|
||||
keyid = ent['keyid']
|
||||
if ent.has_key('filename'):
|
||||
filename = ent['filename']
|
||||
source = ent['source']
|
||||
if source.startswith("deb"):
|
||||
sources.append(source)
|
||||
|
||||
return (keyserver,sources,keyid,filename)
|
3
setup.py
3
setup.py
@ -31,7 +31,8 @@ setup(name='EC2-init',
|
||||
packages=['ec2init'],
|
||||
scripts=['ec2-init.py',
|
||||
'ec2-is-compat-env',
|
||||
'cloud-init-run-module.py'
|
||||
'cloud-init-run-module.py',
|
||||
'cloud-init-cfg.py'
|
||||
],
|
||||
data_files=[('/etc/ec2-init', ['ec2-config.cfg']),
|
||||
('/etc/ec2-init/templates', glob('templates/*')),
|
||||
|
@ -6,7 +6,7 @@ description "Update software at boot"
|
||||
|
||||
start on (cloud-config
|
||||
and local-filesystem
|
||||
and net-device-iup IFACE=eth0)
|
||||
and net-device-up IFACE=eth0)
|
||||
console output
|
||||
|
||||
exec /usr/sbin/ec2-update-software
|
||||
exec cloud-init-cfg apt-update-upgrade
|
@ -6,8 +6,8 @@ description "Download preconfigured ssh keys"
|
||||
|
||||
start on (cloud-config
|
||||
and local-filesystem
|
||||
and net-device-ifup IFACE=eth0)
|
||||
console out
|
||||
and net-device-ifup IFACE=eth0 and starting ssh)
|
||||
console output
|
||||
task
|
||||
|
||||
exec /usr/sbin/ec2-preconf-ssh-keys
|
||||
exec cloud-init-cfg config-ssh
|
@ -9,4 +9,4 @@ start on cloud-config
|
||||
console output
|
||||
task
|
||||
|
||||
exec /usr/sbin/ec2-ebs-mount
|
||||
exec cloud-init-cfg ec2-ebs-mounts
|
@ -9,4 +9,4 @@ start on (cloud-config
|
||||
console output
|
||||
task
|
||||
|
||||
exec /usr/sbin/ec2-setup-raid
|
||||
exec cloud-init-cfg setup-raid
|
@ -3,7 +3,7 @@
|
||||
|
||||
description "execute cloud user scripts"
|
||||
|
||||
start on (stopped rc RUNLEVEL=[2345] and cloud-config)
|
||||
start on (stopped ec2init and stopped rc RUNLEVEL=[2345])
|
||||
console output
|
||||
task
|
||||
|
||||
|
@ -10,4 +10,4 @@ start on (cloud-config
|
||||
console output
|
||||
task
|
||||
|
||||
exec /usr/sbin/ec2-runurl
|
||||
exec cloud-init-cfg runurl
|
@ -1,13 +0,0 @@
|
||||
# ec2-apt-update - Update archive at boot time
|
||||
#
|
||||
# Update archive at boot
|
||||
|
||||
description "Update archive at boot"
|
||||
|
||||
start on (cloud-config
|
||||
and local-filesystems
|
||||
and net-device-up IFACE=eth0)
|
||||
console output
|
||||
task
|
||||
# exec /usr/sbin/cloud-init-run --once ec2-apt-update ec2-apt-update
|
||||
exec /usr/sbin/ec2-apt-update
|
Loading…
x
Reference in New Issue
Block a user