2021-05-12 05:31:10 +12:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# (c) 2020, Alexei Znamensky <russoz@gmail.com>
|
2022-08-05 12:28:29 +02:00
|
|
|
# Copyright (c) 2020, Ansible Project
|
|
|
|
# Simplified BSD License (see LICENSES/BSD-2-Clause.txt or https://opensource.org/licenses/BSD-2-Clause)
|
|
|
|
# SPDX-License-Identifier: BSD-2-Clause
|
2021-05-12 05:31:10 +12:00
|
|
|
|
|
|
|
from __future__ import absolute_import, division, print_function
|
|
|
|
__metaclass__ = type
|
|
|
|
|
|
|
|
from ansible.module_utils.basic import AnsibleModule
|
|
|
|
from ansible_collections.community.general.plugins.module_utils.mh.exceptions import ModuleHelperException as _MHE
|
|
|
|
from ansible_collections.community.general.plugins.module_utils.mh.deco import module_fails_on_exception
|
|
|
|
|
|
|
|
|
|
|
|
class ModuleHelperBase(object):
|
|
|
|
module = None
|
|
|
|
ModuleHelperException = _MHE
|
2022-05-09 17:10:49 +12:00
|
|
|
_delegated_to_module = (
|
|
|
|
'check_mode', 'get_bin_path', 'warn', 'deprecate',
|
|
|
|
)
|
2021-05-12 05:31:10 +12:00
|
|
|
|
|
|
|
def __init__(self, module=None):
|
|
|
|
self._changed = False
|
|
|
|
|
|
|
|
if module:
|
|
|
|
self.module = module
|
|
|
|
|
|
|
|
if not isinstance(self.module, AnsibleModule):
|
|
|
|
self.module = AnsibleModule(**self.module)
|
|
|
|
|
2022-05-09 17:10:49 +12:00
|
|
|
@property
|
|
|
|
def diff_mode(self):
|
|
|
|
return self.module._diff
|
|
|
|
|
2022-07-31 21:28:17 +12:00
|
|
|
@property
|
|
|
|
def verbosity(self):
|
|
|
|
return self.module._verbosity
|
|
|
|
|
2022-05-14 06:40:17 +12:00
|
|
|
def do_raise(self, *args, **kwargs):
|
|
|
|
raise _MHE(*args, **kwargs)
|
|
|
|
|
2022-05-09 17:10:49 +12:00
|
|
|
def __getattr__(self, attr):
|
|
|
|
if attr in self._delegated_to_module:
|
|
|
|
return getattr(self.module, attr)
|
|
|
|
raise AttributeError("ModuleHelperBase has no attribute '%s'" % (attr, ))
|
|
|
|
|
2021-05-12 05:31:10 +12:00
|
|
|
def __init_module__(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def __run__(self):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
def __quit_module__(self):
|
|
|
|
pass
|
|
|
|
|
2021-05-18 06:28:21 +12:00
|
|
|
def __changed__(self):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
2021-05-12 05:31:10 +12:00
|
|
|
@property
|
|
|
|
def changed(self):
|
2021-05-18 06:28:21 +12:00
|
|
|
try:
|
|
|
|
return self.__changed__()
|
|
|
|
except NotImplementedError:
|
|
|
|
return self._changed
|
2021-05-12 05:31:10 +12:00
|
|
|
|
|
|
|
@changed.setter
|
|
|
|
def changed(self, value):
|
|
|
|
self._changed = value
|
|
|
|
|
|
|
|
def has_changed(self):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
@property
|
|
|
|
def output(self):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
@module_fails_on_exception
|
|
|
|
def run(self):
|
|
|
|
self.__init_module__()
|
|
|
|
self.__run__()
|
|
|
|
self.__quit_module__()
|
2021-07-01 18:53:48 +02:00
|
|
|
output = self.output
|
|
|
|
if 'failed' not in output:
|
|
|
|
output['failed'] = False
|
|
|
|
self.module.exit_json(changed=self.has_changed(), **output)
|
2021-08-17 20:43:18 +12:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def execute(cls, module=None):
|
|
|
|
cls(module).run()
|