Skip to main content

asyncio-based Python wrapper for the Rocket.Chat Realtime API.

Project description

rocketchat-async

asyncio-based Python wrapper for the Rocket.Chat Realtime API.

Supported Rocket.Chat versions: 6.x. (The library might also work or partially work with other versions.)

When should you use this library?

Use this library if you:

  • want to integrate with Rocket.Chat from Python
  • are using asyncio to drive your code
  • want to use Rocket.Chat's efficient websockets-based Realtime API

Installation

pip install rocketchat-async

Example usage

import asyncio
import random
from rocketchat_async import RocketChat


def handle_message(channel_id, sender_id, msg_id, thread_id, msg, qualifier,
                   unread, repeated):
    """Simply print the message that arrived."""
    print(msg)


async def main(address, username, password):
    while True:
        try:
            rc = RocketChat()
            await rc.start(address, username, password)
            # Alternatively, use rc.resume for token-based authentication:
            # await rc.resume(address, username, token)

            # A possible workflow consists of two steps:
            #
            # 1. Set up the desired callbacks...
            for channel_id, channel_type in await rc.get_channels():
                await rc.subscribe_to_channel_messages(channel_id,
                                                       handle_message)
            # 2. ...and then simply wait for the registered events.
            await rc.run_forever()
        except (RocketChat.ConnectionClosed,
                RocketChat.ConnectCallFailed) as e:
            print(f'Connection failed: {e}. Waiting a few seconds...')
            await asyncio.sleep(random.uniform(4, 8))
            print('Reconnecting...')


# Side note: Don't forget to use the wss:// scheme when TLS is used.
asyncio.run(main('ws://localhost:3000/websocket', 'username', 'password'))

API Overview

Brief overview of the currently implemented methods.

As of now, Rocket.Chat's API is only covered partially (based on my original needs). I am open to both feature requests as well as pull requests.

Methods

RocketChat.get_channels()

Get a list of channels the logged-in user is currently member of.

RocketChat.send_message(text, channel_id, thread_id=None)

Send a text message to a channel.

RocketChat.send_reaction(orig_msg_id, emoji)

Send a reaction to a specific message.

RocketChat.send_typing_event(channel_id, thread_id=None)

Send the "typing" event to a channel or to a specified thread within that channel.

RocketChat.subscribe_to_channel_messages(channel_id, callback)

Subscribe to all messages in the given channel. Returns the subscription ID.

The provided callback should accept eight arguments: channel_id, sender_id, msg_id, thread_id, msg_text, msg_qualifier and repeated. The qualifier can help to determine if e.g. the message is a system message about the user being removed from the channel. The repeated flag assists in distinguishing whether the message has been received again as a result of thread replies, or if it is a new message post.

RocketChat.subscribe_to_channel_changes(callback)

Subscribe to all changes in channels. Returns the subscription ID.

The provided callback should accept two arguments: channel_id and channel_qualifier. The qualifier helps to determine e.g. if it's a direct message or a normal room.

RocketChat.subscribe_to_channel_changes_raw(callback)

Like RocketChat.subscribe_to_channel_changes except the callback gets passed the raw message object coming from the API.

RocketChat.subscribe_to_channel_messages_raw(channel_id, callback)

Like RocketChat.subscribe_to_channel_messages except the callback gets passed the raw message object coming from the API.

RocketChat.get_channels_raw()

Like RocketChat.get_channels except the method returns the list of raw channel objects coming from the API.

RocketChat.unsubscribe(subscription_id)

Cancel a subscription.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rocketchat_async-4.2.0.tar.gz (9.1 kB view details)

Uploaded Source

Built Distribution

rocketchat_async-4.2.0-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file rocketchat_async-4.2.0.tar.gz.

File metadata

  • Download URL: rocketchat_async-4.2.0.tar.gz
  • Upload date:
  • Size: 9.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.9.2 Linux/5.10.0-30-amd64

File hashes

Hashes for rocketchat_async-4.2.0.tar.gz
Algorithm Hash digest
SHA256 caacf2946a5faf9e78f2ed9e418d67e69d99b61e04e1f5c65dcfeedf96cf1b85
MD5 b8426511f044d38301bc927e9ae52c3d
BLAKE2b-256 3e30f9f1ba1c2901d8543b0c76e03df4bbe18c1c7cdc51d880887a246df5a78b

See more details on using hashes here.

File details

Details for the file rocketchat_async-4.2.0-py3-none-any.whl.

File metadata

  • Download URL: rocketchat_async-4.2.0-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.9.2 Linux/5.10.0-30-amd64

File hashes

Hashes for rocketchat_async-4.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2b7b1b50470f2fa7d04f9022e50e3b95b9809d67eb5f1681e825e79de42a9bad
MD5 1a53faf2d82140a3e4cda8ffe324409a
BLAKE2b-256 c624385725c8b50cc80e3c2a0c1793981d00ec47fbcdf4a40d220d036ead2c9b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page