diff options
author | Scott Moser <smoser@ubuntu.com> | 2010-02-04 02:31:53 -0500 |
---|---|---|
committer | Scott Moser <smoser@ubuntu.com> | 2010-02-04 02:31:53 -0500 |
commit | ef8789ded2636f35d554cb9d620d8057591ca39a (patch) | |
tree | 66c38ebc8030d6eb23dead31c1164db4fa91dd6e /cloud-init.py | |
parent | 3f7bb3e1fbc7b466c98c884bea81a4c608672333 (diff) | |
download | vyos-cloud-init-ef8789ded2636f35d554cb9d620d8057591ca39a.tar.gz vyos-cloud-init-ef8789ded2636f35d554cb9d620d8057591ca39a.zip |
more removal of 'ec2init' string, replacement with cloud-init
Diffstat (limited to 'cloud-init.py')
-rwxr-xr-x | cloud-init.py | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/cloud-init.py b/cloud-init.py new file mode 100755 index 00000000..723ae3df --- /dev/null +++ b/cloud-init.py @@ -0,0 +1,60 @@ +#!/usr/bin/python + +import subprocess +import sys + +import cloudinit +import cloudinit.util as util + +def warn(str): + sys.stderr.write(str) + +def main(): + cloud = cloudinit.EC2Init() + + try: + cloud.get_data_source() + except Exception as e: + print e + sys.stderr.write("Failed to get instance data") + sys.exit(1) + + hostname = cloud.get_hostname() + subprocess.Popen(['hostname', hostname]).communicate() + #print "user data is:" + cloud.get_user_data() + + # store the metadata + cloud.update_cache() + + # parse the user data (ec2-run-userdata.py) + try: + cloud.sem_and_run("consume_userdata", "once-per-instance", + cloud.consume_userdata,[],False) + except: + warn("consuming user data failed!\n") + raise + + # set the defaults (like what ec2-set-defaults.py did) + try: + cloud.sem_and_run("set_defaults", "once-per-instance", + set_defaults,[ cloud ],False) + except: + warn("failed to set defaults\n") + + # finish, send the cloud-config event + cloud.initctl_emit() + + sys.exit(0) + +def set_defaults(cloud): + apply_locale(cloud.get_locale()) + +def apply_locale(locale): + subprocess.Popen(['locale-gen', locale]).communicate() + subprocess.Popen(['update-locale', locale]).communicate() + + util.render_to_file('default-locale', '/etc/default/locale', \ + { 'locale' : locale }) + +if __name__ == '__main__': + main() |