/robrix

Robrix: a multi-platform Matrix chat client written in Rust using the Makepad UI toolkit and the Robius app dev framework

Primary LanguageRustMIT LicenseMIT

Robrix: a Rust Matrix client built atop Robius

Robrix Matrix Chat Project Robius Matrix Chat

Robrix is a Matrix chat client written in Rust to demonstrate the functionality of Project Robius, a framework for multi-platform application development in Rust.

▶️ Click here to see the Robrix project tracker!

⚠️ Robrix is a work-in-progress that doesn't yet support all Matrix chat features.

Note that only the first "Rooms" tab of the UI is in use.

Check out our most recent talks and presentations for more info:

The following table shows which host systems can currently be used to build Robrix for which target platforms.

Host OS Target Platform Builds? Runs?
macOS macOS
macOS Android
macOS iOS
Linux Linux
Linux Android
Windows Windows
Windows Android

Building and Running

First, install Rust.

Then, install the required native libraries. For example, on Linux:

sudo apt-get install libsqlite3-dev libssl-dev

Then, on a standard desktop platform (macOS, Linux, Windows), simply run:

cargo run -- 'USERNAME' 'PASSWORD' ['HOMESERVER_URL']
  • Robrix only supports a standard username + password login currently.
    • Note the usage of single quotes (not double quotes), which will prevent your shell from treating certain symbols as globs/regex patterns.
    • If you created your Matrix account using a third-party Single Sign On (SSO) like a Google account, you can set a standard password by using Element's password reset form.
  • The HOMESERVER_URL argument is optional and uses the "https://matrix-client.matrix.org/" URL by default.

Building Robrix for Android

  1. Install the cargo-makepad build tool:

    cargo install --force --git https://github.com/makepad/makepad.git --branch rik cargo-makepad
  2. Use cargo-makepad to install the Android toolchain, with the full NDK:

    cargo makepad android install-toolchain --full-ndk
  3. Build and run Robrix using cargo-makepad:

    • Fill in your username and password in the login.toml file.
    • Then use cargo makepad to build and run:
      cargo makepad android run -p robrix --release
    • You'll need to connect a physical Android device with developer options enabled, or start up an emulator using Android Studio.
      • API version 33 or higher is required, which is Android 13 and up.

Feature status tracker

These are generally sorted in order of priority. If you're interested in helping out with anything here, please reach out via a GitHub issue or on our Robius matrix channel.

Basic room views and fundamental actions

  • View list of joined rooms
  • View timeline of events in a single room
  • Fetch and display room avatars
  • Fetch user profiles (displayable names)
  • Fetch and display user profile avatars
  • Backwards pagination (upon viewing a room timeline)
  • Dynamic backwards pagination based on scroll position/movement: #109
  • Loading animation while waiting for pagination request: #109
  • Stable positioning of events during timeline update
  • Stable positioning of events after a full timeline clear: #103
  • Display simple text-only messages
  • Display image messages (PNG, JPEG)
  • Rich text formatting for message bodies
  • Display multimedia (audio/video/gif) message events: #120
  • Display reactions (annotations)
  • Handle opening links on click
  • Linkify plaintext hyperlinks
  • Link previews beneath messages: #81
  • Reply previews above messages: #82
  • Send messages (standalone, no replies)
  • Interactive reaction button, send reactions: #115
  • Reply button, send reply: #83
  • Error display banners: no connection, failure to login, sync timeout: #121
  • Collapsible/expandable view of contiguous "small" events: #118
  • E2EE device verification, decrypt message content: #116

Auxiliary/admin features: login, registration, settings

  • Username/password login screen: #113
  • SSO, other 3rd-party auth providers login screen: #114
  • Dedicated view of spaces
  • Dedicated view of direct messages (DMs)
  • Keyword filters for the list of all rooms: #123
  • Search messages within a room: #122
  • Room browser, search for public rooms
  • Room creation
  • Room settings/info screen
  • Room members pane
  • Side panel showing detailed user profile info (click on their Avatar)
  • Ignore and unignore users (see known issues)
  • User settings screen
  • Persistence of app state to disk: #112

Known problems/issues

  • URLs do not wrap properly; that is a Makepad-side problem.
  • Matrix-specific links are not yet fully handled (https://matrix.to/...)
  • Ignoring/unignoring a user clears all timelines (see: matrix-org/matrix-rust-sdk#1703); the timeline will be re-filled using gradual pagination, but the viewport is not maintained