Skip to main content

Client-Server SDK for Matrix

Project description

Matrix Client SDK for Python

Latest Version Travis-CI Results coveralls.io Results Matrix chatroom Documentation

Matrix client-server SDK for Python 2.7 and 3.4+

Project Status

We strongly recommend using the matrix-nio library rather than this sdk. It is both more featureful and more actively maintained.

This sdk is currently lightly maintained without any person ultimately responsible for the project. Pull-requests may be reviewed, but no new-features or bug-fixes are being actively developed. For more info or to volunteer to help, please see https://github.com/matrix-org/matrix-python-sdk/issues/279 or come chat in #matrix-python-sdk:matrix.org.

Installation

Stable release

Install with pip from pypi. This will install all necessary dependencies as well.

pip install matrix_client

Development version

Install using setup.py in root project directory. This will also install all needed dependencies.

git clone https://github.com/matrix-org/matrix-python-sdk.git
cd matrix-python-sdk
python setup.py install

Usage

The SDK provides 2 layers of interaction. The low-level layer just wraps the raw HTTP API calls. The high-level layer wraps the low-level layer and provides an object model to perform actions on.

Client:

from matrix_client.client import MatrixClient

client = MatrixClient("http://localhost:8008")

# New user
token = client.register_with_password(username="foobar", password="monkey")

# Existing user
token = client.login(username="foobar", password="monkey")

room = client.create_room("my_room_alias")
room.send_text("Hello!")

API:

from matrix_client.api import MatrixHttpApi

matrix = MatrixHttpApi("https://matrix.org", token="some_token")
response = matrix.send_message("!roomid:matrix.org", "Hello!")

Structure

The SDK is split into two modules: api and client.

API

This contains the raw HTTP API calls and has minimal business logic. You can set the access token (token) to use for requests as well as set a custom transaction ID (txn_id) which will be incremented for each request.

Client

This encapsulates the API module and provides object models such as Room.

Samples

A collection of samples are included, written in Python 3.

You can either install the SDK, or run the sample like this:

PYTHONPATH=. python samples/samplename.py

Building the Documentation

The documentation can be built by installing sphinx and sphinx_rtd_theme.

Simple run make inside docs which will list the avaliable output formats.

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

matrix_client-0.4.0.tar.gz (49.0 kB view details)

Uploaded Source

Built Distribution

matrix_client-0.4.0-py2.py3-none-any.whl (43.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file matrix_client-0.4.0.tar.gz.

File metadata

  • Download URL: matrix_client-0.4.0.tar.gz
  • Upload date:
  • Size: 49.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for matrix_client-0.4.0.tar.gz
Algorithm Hash digest
SHA256 0678af40f2cb2f0928a908a410c029747d40cb961ac5a3f1bd05aa35563c3156
MD5 441c37175eeba25ad36632c1be1fa60a
BLAKE2b-256 939a23c4894da5aeb316903677c71014575c486616026b85e2d0b408f84d8540

See more details on using hashes here.

Provenance

File details

Details for the file matrix_client-0.4.0-py2.py3-none-any.whl.

File metadata

  • Download URL: matrix_client-0.4.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 43.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for matrix_client-0.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 20cb42fb644879858c3fdd348d1c349c33676f11d1597f820abfd0fc0e009cb1
MD5 0a2371dc78da84d9f63c9abf3e787dbe
BLAKE2b-256 6100f10d4b5d72c5afb9b703ea0cabbea1670cd20159afe1764f4322d00dec99

See more details on using hashes here.

Provenance

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