Source code for saltfactories.cli.cloud

"""
``salt-cloud`` CLI factory.
"""
import logging
import pathlib
import pprint
import urllib.parse

import attr
import yaml

from saltfactories.bases import SaltCli
from saltfactories.utils import running_username

log = logging.getLogger(__name__)


[docs] @attr.s(kw_only=True, slots=True) class SaltCloud(SaltCli): """ salt-cloud CLI factory. """
[docs] @staticmethod def default_config(root_dir, master_id, defaults=None, overrides=None): """ Return the default configuration for the daemon. """ # Do not move these deferred imports. It allows running against a Salt # onedir build in salt's repo checkout. import salt.utils.dictupdate if defaults is None: defaults = {} conf_dir = root_dir / "conf" conf_dir.mkdir(parents=True, exist_ok=True) for confd in ("cloud.conf.d", "cloud.providers.d", "cloud.profiles.d"): dpath = conf_dir / confd dpath.mkdir(exist_ok=True) conf_file = str(conf_dir / "cloud") _defaults = { "conf_file": conf_file, "root_dir": str(root_dir), "log_file": "logs/cloud.log", "log_level_logfile": "debug", "pytest-cloud": { "master-id": master_id, "log": {"prefix": f"{{cli_name}}({master_id})"}, }, } # Merge in the initial default options with the internal _defaults salt.utils.dictupdate.update(defaults, _defaults, merge_lists=True) if overrides: # Merge in the default options with the master_overrides salt.utils.dictupdate.update(defaults, overrides, merge_lists=True) return defaults
[docs] @classmethod def configure( cls, factories_manager, # pylint: disable=unused-argument daemon_id, # pylint: disable=unused-argument root_dir=None, defaults=None, overrides=None, **configure_kwargs, # pylint: disable=unused-argument ): """ Configure the CLI. """ return cls.default_config(root_dir, daemon_id, defaults=defaults, overrides=overrides)
[docs] @classmethod def verify_config(cls, config): """ Verify the configuration dictionary. """ # Do not move these deferred imports. It allows running against a Salt # onedir build in salt's repo checkout. import salt.config import salt.utils.verify prepend_root_dirs = [] for config_key in ("log_file",): if urllib.parse.urlparse(config.get(config_key, "")).scheme == "": prepend_root_dirs.append(config_key) if prepend_root_dirs: salt.config.prepend_root_dir(config, prepend_root_dirs) salt.utils.verify.verify_env( [str(pathlib.Path(config["log_file"]).parent)], running_username(), pki_dir=config.get("pki_dir") or "", root_dir=config["root_dir"], )
[docs] @classmethod def write_config(cls, config): """ Verify the loaded configuration. """ # Do not move these deferred imports. It allows running against a Salt # onedir build in salt's repo checkout. import salt.config # pylint: disable=import-outside-toplevel cls.verify_config(config) config_file = config.pop("conf_file") log.debug( "Writing to configuration file %s. Configuration:\n%s", config_file, pprint.pformat(config), ) # Write down the computed configuration into the config file with open(config_file, "w", encoding="utf-8") as wfh: yaml.safe_dump(config, wfh, default_flow_style=False) return salt.config.cloud_config(config_file)