2021-05-11 20:05:42 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# (c) 2020, Alexei Znamensky <russoz@gmail.com>
|
|
|
|
# Copyright: (c) 2020, Ansible Project
|
|
|
|
# Simplified BSD License (see licenses/simplified_bsd.txt or https://opensource.org/licenses/BSD-2-Clause)
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
|
def __init__(self, module=None):
|
|
|
|
self._changed = False
|
|
|
|
|
|
|
|
if module:
|
|
|
|
self.module = module
|
|
|
|
|
|
|
|
if not isinstance(self.module, AnsibleModule):
|
|
|
|
self.module = AnsibleModule(**self.module)
|
|
|
|
|
|
|
|
def __init_module__(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def __run__(self):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
|
|
|
def __quit_module__(self):
|
|
|
|
pass
|
|
|
|
|
2021-05-17 20:50:43 +02:00
|
|
|
def __changed__(self):
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
2021-05-11 20:05:42 +02:00
|
|
|
@property
|
|
|
|
def changed(self):
|
2021-05-17 20:50:43 +02:00
|
|
|
try:
|
|
|
|
return self.__changed__()
|
|
|
|
except NotImplementedError:
|
|
|
|
return self._changed
|
2021-05-11 20:05:42 +02: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 19:33:47 +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 11:29:11 +02:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def execute(cls, module=None):
|
|
|
|
cls(module).run()
|