diff options
author | Scott Moser <smoser@ubuntu.com> | 2013-07-11 10:16:18 -0400 |
---|---|---|
committer | Scott Moser <smoser@ubuntu.com> | 2013-07-11 10:16:18 -0400 |
commit | 8c15320283012d218c2165f5dfb38a29d2cf7b53 (patch) | |
tree | 3995802ea04a4af71c4e061355b4c0214d2c76c2 /cloudinit/sources/DataSourceAzure.py | |
parent | 299af1d4a3e09ad9c961cb641e62a20ab5998640 (diff) | |
download | vyos-cloud-init-8c15320283012d218c2165f5dfb38a29d2cf7b53.tar.gz vyos-cloud-init-8c15320283012d218c2165f5dfb38a29d2cf7b53.zip |
DataSourceAzure.py: allow 'customdata' to be the name for userdata
Also, fix a comment and write a log message on how long we waited
for the files to appear.
Diffstat (limited to 'cloudinit/sources/DataSourceAzure.py')
-rw-r--r-- | cloudinit/sources/DataSourceAzure.py | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/cloudinit/sources/DataSourceAzure.py b/cloudinit/sources/DataSourceAzure.py index 200bede5..2818408c 100644 --- a/cloudinit/sources/DataSourceAzure.py +++ b/cloudinit/sources/DataSourceAzure.py @@ -119,9 +119,13 @@ class DataSourceAzureNet(sources.DataSource): bname = pk['fingerprint'] + ".crt" fp_files += [os.path.join(mycfg['datadir'], bname)] + start = time.time() missing = wait_for_files(wait_for + fp_files) if len(missing): - LOG.warn("Did not find files, but going on: %s" % missing) + LOG.warn("Did not find files, but going on: %s", missing) + else: + LOG.debug("waited %.3f seconds for %d files to appear", + time.time() - start, len(wait_for)) pubkeys = pubkeys_from_crt_files(fp_files) @@ -197,7 +201,8 @@ def find_child(node, filter_func): def load_azure_ovf_pubkeys(sshnode): - # in the future this would return a list of dicts like: + # This parses a 'SSH' node formatted like below, and returns + # an array of dicts. # [{'fp': '6BE7A7C3C8A8F4B123CCA5D0C2F1BE4CA7B63ED7', # 'path': 'where/to/go'}] # @@ -293,7 +298,9 @@ def read_azure_ovf(contents): simple = True value = child.childNodes[0].wholeText - if name == "userdata": + # we accept either UserData or CustomData. If both are present + # then behavior is undefined. + if (name == "userdata" or name == "customdata"): ud = base64.b64decode(''.join(value.split())) elif name == "username": username = value |