summaryrefslogtreecommitdiff
path: root/cloudinit/CloudConfig/cc_puppet.py
diff options
context:
space:
mode:
authorScott Moser <smoser@ubuntu.com>2011-02-18 18:42:52 -0500
committerScott Moser <smoser@ubuntu.com>2011-02-18 18:42:52 -0500
commit6a5af453d45c17e2f8f2941d79410773df11cd23 (patch)
tree4e17deb415177932c8a7cbe8be7b460ad9e9c98a /cloudinit/CloudConfig/cc_puppet.py
parentb36409906bb374ea17e5fd3f7e0a9eda93fed4fa (diff)
parent2492df4fbdd54d9c8b3e172db53ee78c1709de84 (diff)
downloadvyos-cloud-init-6a5af453d45c17e2f8f2941d79410773df11cd23.tar.gz
vyos-cloud-init-6a5af453d45c17e2f8f2941d79410773df11cd23.zip
Update puppet to replace rather than append, add mcollective [Marc Cluet]
Modified puppet module to try to replace values on the existing file instead of adding new values to the end. Also added initial mcollective module
Diffstat (limited to 'cloudinit/CloudConfig/cc_puppet.py')
-rw-r--r--cloudinit/CloudConfig/cc_puppet.py26
1 files changed, 22 insertions, 4 deletions
diff --git a/cloudinit/CloudConfig/cc_puppet.py b/cloudinit/CloudConfig/cc_puppet.py
index b498c5f0..c458365d 100644
--- a/cloudinit/CloudConfig/cc_puppet.py
+++ b/cloudinit/CloudConfig/cc_puppet.py
@@ -19,6 +19,8 @@ import os
import pwd
import socket
import subprocess
+import StringIO
+import ConfigParser
import cloudinit.CloudConfig as cc
def handle(name,cfg,cloud,log,args):
@@ -31,7 +33,13 @@ def handle(name,cfg,cloud,log,args):
# ... and then update the puppet configuration
if puppet_cfg.has_key('conf'):
# Add all sections from the conf object to puppet.conf
- puppet_conf_fh = open('/etc/puppet/puppet.conf', 'a')
+ puppet_conf_fh = open('/etc/puppet/puppet.conf', 'r')
+ # Create object for reading puppet.conf values
+ puppet_config = ConfigParser.ConfigParser()
+ # Read puppet.conf values from original file in order to be able to mix the rest up
+ puppet_config.readfp(StringIO.StringIO(''.join(i.lstrip() for i in puppet_conf_fh.readlines())))
+ # Close original file, no longer needed
+ puppet_conf_fh.close()
for cfg_name, cfg in puppet_cfg['conf'].iteritems():
# ca_cert configuration is a special case
# Dump the puppetmaster ca certificate in the correct place
@@ -51,7 +59,12 @@ def handle(name,cfg,cloud,log,args):
os.chown('/var/lib/puppet/ssl/certs/ca.pem',
pwd.getpwnam('puppet').pw_uid, 0)
else:
- puppet_conf_fh.write("\n[%s]\n" % (cfg_name))
+ #puppet_conf_fh.write("\n[%s]\n" % (cfg_name))
+ # If puppet.conf already has this section we don't want to write it again
+ if puppet_config.has_section(cfg_name) == False
+ puppet_config.add_section(cfg_name)
+ # Iterate throug the config items, we'll use ConfigParser.set
+ # to overwrite or create new items as needed
for o, v in cfg.iteritems():
if o == 'certname':
# Expand %f as the fqdn
@@ -61,8 +74,13 @@ def handle(name,cfg,cloud,log,args):
cloud.datasource.get_instance_id())
# certname needs to be downcase
v = v.lower()
- puppet_conf_fh.write("%s=%s\n" % (o, v))
- puppet_conf_fh.close()
+ puppet_config.set(cfg_name,o,v)
+ #puppet_conf_fh.write("%s=%s\n" % (o, v))
+ # We got all our config as wanted we'll rename
+ # the previous puppet.conf and create our new one
+ os.rename('/etc/puppet/puppet.conf','/etc/puppet/puppet.conf.old')
+ with open('/etc/puppet/puppet.conf', 'wb') as configfile:
+ puppet_config.write(configfile)
# Set puppet default file to automatically start
subprocess.check_call(['sed', '-i',
'-e', 's/^START=.*/START=yes/',