123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- """
- Ansible action plugin to ensure inventory variables are set
- appropriately and no conflicting options have been provided.
- """
- from ansible.plugins.action import ActionBase
- from ansible import errors
- # Valid values for openshift_deployment_type
- VALID_DEPLOYMENT_TYPES = ('origin', 'openshift-enterprise')
- # Tuple of variable names and default values if undefined.
- NET_PLUGIN_LIST = (('openshift_use_openshift_sdn', True),
- ('openshift_use_flannel', False),
- ('openshift_use_nuage', False),
- ('openshift_use_contiv', False),
- ('openshift_use_calico', False))
- def to_bool(var_to_check):
- """Determine a boolean value given the multiple
- ways bools can be specified in ansible."""
- # http://yaml.org/type/bool.html
- yes_list = (True, 1, "True", "1", "true", "TRUE",
- "Yes", "yes", "Y", "y", "YES",
- "on", "ON", "On")
- return var_to_check in yes_list
- class ActionModule(ActionBase):
- """Action plugin to execute sanity checks."""
- def template_var(self, hostvars, host, varname):
- """Retrieve a variable from hostvars and template it.
- If undefined, return None type."""
- res = hostvars[host].get(varname)
- if res is None:
- return None
- return self._templar.template(res)
- def check_openshift_deployment_type(self, hostvars, host):
- """Ensure a valid openshift_deployment_type is set"""
- openshift_deployment_type = self.template_var(hostvars, host,
- 'openshift_deployment_type')
- if openshift_deployment_type not in VALID_DEPLOYMENT_TYPES:
- type_strings = ", ".join(VALID_DEPLOYMENT_TYPES)
- msg = "openshift_deployment_type must be defined and one of {}".format(type_strings)
- raise errors.AnsibleModuleError(msg)
- def check_python_version(self, hostvars, host, distro):
- """Ensure python version is 3 for Fedora and python 2 for others"""
- ansible_python = self.template_var(hostvars, host, 'ansible_python')
- if distro == "Fedora":
- if ansible_python['version']['major'] != 3:
- msg = "openshift-ansible requires Python 3 for {};".format(distro)
- msg += " For information on enabling Python 3 with Ansible,"
- msg += " see https://docs.ansible.com/ansible/python_3_support.html"
- raise errors.AnsibleModuleError(msg)
- else:
- if ansible_python['version']['major'] != 2:
- msg = "openshift-ansible requires Python 2 for {};".format(distro)
- def network_plugin_check(self, hostvars, host):
- """Ensure only one type of network plugin is enabled"""
- res = []
- # Loop through each possible network plugin boolean, determine the
- # actual boolean value, and append results into a list.
- for plugin, default_val in NET_PLUGIN_LIST:
- res_temp = self.template_var(hostvars, host, plugin)
- if res_temp is None:
- res_temp = default_val
- res.append(to_bool(res_temp))
- if sum(res) != 1:
- plugin_str = list(zip([x[0] for x in NET_PLUGIN_LIST], res))
- msg = "Host Checked: {} Only one of must be true. Found: {}".format(host, plugin_str)
- raise errors.AnsibleModuleError(msg)
- def check_hostname_vars(self, hostvars, host):
- """Checks to ensure openshift_hostname
- and openshift_public_hostname
- conform to the proper length of 63 characters or less"""
- for varname in ('openshift_public_hostname', 'openshift_hostname'):
- var_value = self.template_var(hostvars, host, varname)
- if var_value and len(var_value) > 63:
- msg = '{} must be 63 characters or less'.format(varname)
- raise errors.AnsibleModuleError(msg)
- def run_checks(self, hostvars, host):
- """Execute the hostvars validations against host"""
- distro = self.template_var(hostvars, host, 'ansible_distribution')
- self.check_openshift_deployment_type(hostvars, host)
- self.check_python_version(hostvars, host, distro)
- self.network_plugin_check(hostvars, host)
- self.check_hostname_vars(hostvars, host)
- def run(self, tmp=None, task_vars=None):
- result = super(ActionModule, self).run(tmp, task_vars)
- # self.task_vars holds all in-scope variables.
- # Ignore settting self.task_vars outside of init.
- # pylint: disable=W0201
- self.task_vars = task_vars or {}
- # self._task.args holds task parameters.
- # check_hosts is a parameter to this plugin, and should provide
- # a list of hosts.
- check_hosts = self._task.args.get('check_hosts')
- if not check_hosts:
- msg = "check_hosts is required"
- raise errors.AnsibleModuleError(msg)
- # We need to access each host's variables
- hostvars = self.task_vars.get('hostvars')
- if not hostvars:
- msg = hostvars
- raise errors.AnsibleModuleError(msg)
- # We loop through each host in the provided list check_hosts
- for host in check_hosts:
- self.run_checks(hostvars, host)
- result["changed"] = False
- result["failed"] = False
- result["msg"] = "Sanity Checks passed"
- return result
|