summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@yahoo-inc.com>2012-06-16 08:54:20 -0700
committerJoshua Harlow <harlowja@yahoo-inc.com>2012-06-16 08:54:20 -0700
commitf0c2776f4e48c6f88958c8ec0d5c8f72ab33cd3a (patch)
tree239d63424255ada7213de74d6bdcecd9b70a3fea
parent5e51d844015160a63c1b4aa5afd39fc0701ed71f (diff)
downloadvyos-cloud-init-f0c2776f4e48c6f88958c8ec0d5c8f72ab33cd3a.tar.gz
vyos-cloud-init-f0c2776f4e48c6f88958c8ec0d5c8f72ab33cd3a.zip
1. Remove content handler iid param, not used.
2. Ensure if iid is found that it is converted to a string before path joining.
-rw-r--r--cloudinit/helpers.py18
1 files changed, 10 insertions, 8 deletions
diff --git a/cloudinit/helpers.py b/cloudinit/helpers.py
index c276a54c..5e47794b 100644
--- a/cloudinit/helpers.py
+++ b/cloudinit/helpers.py
@@ -80,16 +80,17 @@ class FileSemaphores(object):
def clear_all(self):
try:
util.del_dir(self.sem_path)
- except (IOError, OSError) as e:
- LOG.debug("Failed deleting semaphore directory %s due to %s",
- self.sem_path, e)
+ except (IOError, OSError):
+ util.logexc(LOG, "Failed deleting semaphore directory %s",
+ self.sem_path)
def _acquire(self, name, freq):
+ # Check again if its been already gotten
if self.has_run(name, freq):
return None
# This is a race condition since nothing atomic is happening
# here, but this should be ok due to the nature of when
- # and where cloud-init runs... (file writing is not a lock..)
+ # and where cloud-init runs... (file writing is not a lock...)
sem_file = self._get_path(name, freq)
contents = "%s: %s\n" % (os.getpid(), time())
try:
@@ -100,9 +101,11 @@ class FileSemaphores(object):
return sem_file
def has_run(self, name, freq):
- if freq == PER_ALWAYS:
+ if not freq or freq == PER_ALWAYS:
return False
sem_file = self._get_path(name, freq)
+ # This isn't really a good atomic check
+ # but it suffices for where and when cloudinit runs
if os.path.exists(sem_file):
return True
return False
@@ -157,10 +160,9 @@ class Runners(object):
class ContentHandlers(object):
- def __init__(self, paths, iid=None):
+ def __init__(self, paths):
self.paths = paths
self.registered = {}
- self.iid = iid
def __contains__(self, item):
return self.is_registered(item)
@@ -245,7 +247,7 @@ class Paths(object):
iid = self.datasource.get_instance_id()
if iid is None:
return None
- ipath = os.path.join(self.cloud_dir, 'instances', iid)
+ ipath = os.path.join(self.cloud_dir, 'instances', str(iid))
add_on = self.lookups.get(name)
if add_on:
ipath = os.path.join(ipath, add_on)