ansible-collection-famedly-.../plugins/module_utils/matrix.py

156 lines
5.3 KiB
Python
Raw Normal View History

# coding: utf-8
# (c) 2021-2022, Famedly GmbH
# GNU Affero General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/agpl-3.0.txt)
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type
import traceback
from ansible.module_utils.basic import AnsibleModule, missing_required_lib
# Check if all required libs can load
LIB_IMP_ERR = None
try:
from nio import AsyncClient, AsyncClientConfig, \
Api, \
LoginResponse, LoginError, \
LogoutResponse, LogoutError, \
RoomGetStateResponse, RoomGetStateError, \
RoomBanResponse, RoomBanError, \
RoomUnbanResponse, RoomUnbanError, \
RoomKickResponse, RoomKickError, \
RoomInviteResponse, RoomInviteError, \
RoomResolveAliasResponse, RoomResolveAliasError, \
JoinedRoomsResponse, JoinedRoomsError
HAS_LIB = True
except ImportError:
LIB_IMP_ERR = traceback.format_exc()
HAS_LIB = False
class AnsibleNioModule:
def __init__(
self,
custom_spec=None,
bypass_checks=False,
no_log=False,
mutually_exclusive=None,
required_together=None,
required_one_of=None,
required_by=None,
add_file_common_args=False,
supports_check_mode=True,
required_if=None,
user_logout=None,
add_default_arguments=True,
):
if add_default_arguments:
if required_by is None:
required_by = {"password": "user_id"}
if required_one_of is None:
required_one_of = [["password", "token"]]
if mutually_exclusive is None:
mutually_exclusive = [["password", "token"]]
if custom_spec is None:
custom_spec = {}
custom_spec = AnsibleNioModule.__common_argument_spec(custom_spec)
else:
if required_by is None:
required_by = {}
if required_one_of is None:
required_one_of = []
if mutually_exclusive is None:
mutually_exclusive = []
if custom_spec is None:
custom_spec = {}
# Create the Ansible module
self.module = AnsibleModule(
argument_spec=custom_spec,
bypass_checks=bypass_checks,
no_log=no_log,
mutually_exclusive=mutually_exclusive,
required_together=required_together,
required_one_of=required_one_of,
add_file_common_args=add_file_common_args,
supports_check_mode=supports_check_mode,
required_if=required_if,
required_by=required_by
)
if user_logout is None:
# If a user/password login is provided, should we logout when exiting?
self.user_logout = self.module.params.get("token") is None
else:
self.user_logout = user_logout
# Make some values from the module easly accessible
self.check_mode = self.module.check_mode
self.params = self.module.params
# Fail when matix-nio is not installed
# WARNING: We don't perform a version check!
if not HAS_LIB:
self.module.fail_json(msg=missing_required_lib("matrix-nio"))
async def matrix_login(self):
# Login with token or supplied user account
if self.module.params.get("token") is None:
self.client = AsyncClient(
self.module.params.get("hs_url"), self.module.params.get("user_id")
)
login_response = await self.client.login(
password=self.module.params.get("password")
)
if isinstance(login_response, LoginResponse):
self.access_token = login_response.access_token
self.device_id = login_response.device_id
else:
result = {
"msg": login_response.message,
"http_status_code": login_response.status_code,
}
self.module.fail_json(**result)
else:
self.client = AsyncClient(self.module.params.get("hs_url"))
self.client.access_token = self.module.params.get("token")
async def matrix_logout(self):
if self.client.logged_in:
request = await self.client.logout()
if isinstance(request, LogoutError):
result = {'msg': request.message}
self.module.fail_json(**result)
async def exit_json(self, **result):
if self.module.params.get('token') is None and self.user_logout is True:
await self.matrix_logout()
await self.client.close()
self.module.exit_json(**result)
async def fail_json(self, **result):
if self.module.params.get('token') is None and self.user_logout is True:
await self.matrix_logout()
await self.client.close()
self.module.fail_json(**result)
@staticmethod
def __common_argument_spec(custom_spec: dict):
argument_spec = dict(
hs_url=dict(type='str', required=True),
user_id=dict(type='str', required=False),
password=dict(type='str', required=False, no_log=True),
token=dict(type='str', required=False, no_log=True)
)
return {**argument_spec, **custom_spec}