diff options
Diffstat (limited to 'cloudinit/sources/__init__.py')
-rw-r--r-- | cloudinit/sources/__init__.py | 35 |
1 files changed, 19 insertions, 16 deletions
diff --git a/cloudinit/sources/__init__.py b/cloudinit/sources/__init__.py index 05c8bfad..dfd1fff3 100644 --- a/cloudinit/sources/__init__.py +++ b/cloudinit/sources/__init__.py @@ -24,9 +24,12 @@ from cloudinit import importer from cloudinit import log as logging from cloudinit import util +from cloudinit.user_data import processor as ud_proc + DEP_FILESYSTEM = "FILESYSTEM" DEP_NETWORK = "NETWORK" DS_PREFIX = 'DataSource' + LOG = logging.getLogger(__name__) @@ -35,26 +38,25 @@ class DataSourceNotFoundException(Exception): class DataSource(object): - def __init__(self, ud_proc, cfg): + def __init__(self, sys_cfg, distro, paths): name = util.obj_name(self) if name.startswith(DS_PREFIX): name = name[DS_PREFIX:] self.cfgname = name - if sys_cfg: - self.sys_cfg = sys_cfg - else: - self.sys_cfg = {} - self.ud_proc = ud_proc + self.sys_cfg = sys_cfg + self.distro = distro + self.paths = paths + self.userdata_proc = ud_proc.UserDataProcessor(paths) self.userdata = None self.metadata = None self.userdata_raw = None self.ds_cfg = util.get_cfg_by_path(self.sys_cfg, - ("datasource", self.cfgname), self.ds_cfg) + ("datasource", self.cfgname), {}) def get_userdata(self): if self.userdata is None: raw_data = self.get_userdata_raw() - self.userdata = self.ud_proc.process(raw_data) + self.userdata = self.userdata_proc.process(raw_data) return self.userdata def get_userdata_raw(self): @@ -85,7 +87,7 @@ class DataSource(object): # than a list. if isinstance(klist, (str)): klist = [klist] - if isinstance(klist, (list)): + if isinstance(klist, (list, set)): for pkey in klist: # there is an empty string at the end of the keylist, trim it if pkey: @@ -105,6 +107,7 @@ class DataSource(object): return 'en_US.UTF-8' def get_local_mirror(self): + # ?? return None def get_instance_id(self): @@ -152,20 +155,18 @@ class DataSource(object): return hostname -def find_source(cfg, ds_deps, cfg_list, pkg_list, **kwargs): +def find_source(sys_cfg, distro, paths, ds_deps, cfg_list, pkg_list): ds_list = list_sources(cfg_list, ds_deps, pkg_list) ds_names = [util.obj_name(f) for f in ds_list] - ds_args = dict(kwargs) - ds_args['cfg'] = cfg LOG.info("Searching for data source in: %s", ds_names) for cls in ds_list: ds = util.obj_name(cls) try: - s = cls(**ds_args) + s = cls(distro, sys_cfg, paths) if s.get_data(): return (s, ds) except Exception as e: - LOG.exception("Getting data from %s failed", ds) + LOG.exception("Getting data from %s failed due to %s", ds, e) msg = "Did not find any data source, searched classes: %s" % (ds_names) raise DataSourceNotFoundException(msg) @@ -187,8 +188,7 @@ def list_sources(cfg_list, depends, pkg_list): if pkg: pkg_name.append(str(pkg)) pkg_name.append(ds_name) - mod_name = ".".join(pkg_name) - mod = importer.import_module(mod_name) + mod = importer.import_module(".".join(pkg_name)) if pkg: mod = getattr(mod, ds_name, None) if not mod: @@ -196,10 +196,13 @@ def list_sources(cfg_list, depends, pkg_list): lister = getattr(mod, "get_datasource_list", None) if not lister: continue + LOG.debug("Seeing if %s matches using function %s", mod, lister) cls_matches = lister(depends) if not cls_matches: continue src_list.extend(cls_matches) + LOG.debug("Found a match for data source %s in %s with matches %s", + ds_name, mod, cls_matches) break return src_list |