# Copyright (C) 2009-2011 Canonical Ltd. # Copyright (C) 2012 Hewlett-Packard Development Company, L.P. # # Author: Scott Moser # Author: Juerg Haefliger # # This file is part of cloud-init. See LICENSE file for license information. """ Emit Upstart ------------ **Summary:** emit upstart configuration Emit upstart configuration for cloud-init modules on upstart based systems. No user configuration should be required. **Internal name:** ``cc_emit_upstart`` **Module frequency:** always **Supported distros:** ubuntu, debian """ import os from cloudinit import log as logging from cloudinit import subp from cloudinit.settings import PER_ALWAYS frequency = PER_ALWAYS distros = ["ubuntu", "debian"] LOG = logging.getLogger(__name__) def is_upstart_system(): if not os.path.isfile("/sbin/initctl"): LOG.debug("no /sbin/initctl located") return False myenv = os.environ.copy() if "UPSTART_SESSION" in myenv: del myenv["UPSTART_SESSION"] check_cmd = ["initctl", "version"] try: (out, _err) = subp.subp(check_cmd, env=myenv) return "upstart" in out except subp.ProcessExecutionError as e: LOG.debug( "'%s' returned '%s', not using upstart", " ".join(check_cmd), e.exit_code, ) return False def handle(name, _cfg, cloud, log, args): event_names = args if not event_names: # Default to the 'cloud-config' # event for backwards compat. event_names = ["cloud-config"] if not is_upstart_system(): log.debug("not upstart system, '%s' disabled", name) return cfgpath = cloud.paths.get_ipath_cur("cloud_config") for n in event_names: cmd = ["initctl", "emit", str(n), "CLOUD_CFG=%s" % cfgpath] try: subp.subp(cmd) except Exception as e: # TODO(harlowja), use log exception from utils?? log.warning("Emission of upstart event %s failed due to: %s", n, e) # vi: ts=4 expandtab