#!/usr/bin/python # coding: utf-8 # (c) 2018, Jan Christian Grünhage # (c) 2020-2021, 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 ANSIBLE_METADATA = { "metadata_version": "1.1", "status": ["preview"], "supported_by": "community", } DOCUMENTATION = """ --- author: "Jan Christian Grünhage (@jcgruenhage)" module: matrix_notification short_description: Send notifications to matrix description: - This module sends html formatted notifications to matrix rooms. version_added: "2.8.0" options: hs_url: description: - URL of the homeserver, where the CS-API is reachable required: true type: str user_id: description: - The user id of the user required: false type: str password: description: - The password to log in with required: false type: str token: description: - Authentication token for the API call required: false type: str msg_plain: description: - Plain text form of the message to send to matrix, usually markdown required: true type: str msg_html: description: - HTML form of the message to send to matrix required: true type: str room_id: description: - ID of the room to send the notification to required: true type: str requirements: - matrix-nio (Python library) """ EXAMPLES = """ - name: Send matrix notification with token matrix_notification: msg_plain: "**hello world**" msg_html: "hello world" room_id: "!12345678:server.tld" hs_url: "https://matrix.org" token: "{{ matrix_auth_token }}" - name: Send matrix notification with user_id and password matrix_notification: msg_plain: "**hello world**" msg_html: "hello world" room_id: "!12345678:server.tld" hs_url: "https://matrix.org" user_id: "ansible_notification_bot" password: "{{ matrix_auth_password }}" """ RETURN = """ """ import asyncio import traceback from ansible.module_utils.basic import missing_required_lib LIB_IMP_ERR = None try: from ansible_collections.famedly.matrix.plugins.module_utils.matrix import ( AnsibleNioModule, ) from nio import RoomSendResponse, RoomSendError HAS_LIB = True except ImportError: LIB_IMP_ERR = traceback.format_exc() HAS_LIB = False async def run_module(): module_args = dict( msg_plain=dict(type="str", required=True), msg_html=dict(type="str", required=True), room_id=dict(type="str", required=True), ) result = dict(changed=False, message="") module = AnsibleNioModule(module_args) if not HAS_LIB: await module.fail_json(msg=missing_required_lib("matrix-nio")) if module.check_mode: result["changed"] = True await module.exit_json(**result) await module.matrix_login() client = module.client # send message response = await client.room_send( room_id=module.params["room_id"], message_type="m.room.message", content={ "msgtype": "m.text", "body": module.params["msg_plain"], "format": "org.matrix.custom.html", "formatted_body": module.params["msg_html"], }, ) if isinstance(response, RoomSendError): await module.fail_json(**result) else: result["changed"] = True await module.exit_json(**result) def main(): asyncio.run(run_module()) if __name__ == "__main__": main()