2019-01-27 16:26:55 +01:00
|
|
|
[![Build Status](https://img.shields.io/travis/poljar/weechat-matrix.svg?style=flat-square)](https://travis-ci.org/poljar/weechat-matrix)
|
2019-05-25 11:49:47 +02:00
|
|
|
[![#weechat-matrix](https://img.shields.io/badge/matrix-%23weechat--matrix:termina.org.uk-blue.svg?style=flat-square)](https://matrix.to/#/!twcBhHVdZlQWuuxBhN:termina.org.uk?via=termina.org.uk&via=matrix.org)
|
2019-01-23 17:18:51 +01:00
|
|
|
[![license](https://img.shields.io/badge/license-ISC-blue.svg?style=flat-square)](https://github.com/poljar/weechat-matrix/blob/master/LICENSE)
|
|
|
|
|
2018-04-09 05:43:04 +02:00
|
|
|
# What is Weechat-Matrix?
|
|
|
|
|
|
|
|
[Weechat](https://weechat.org/) is an extensible chat client.
|
|
|
|
|
|
|
|
[Matrix](https://matrix.org/blog/home) is an open network for secure, decentralized communication.
|
|
|
|
|
|
|
|
[Weechat-Matrix](https://github.com/poljar/weechat-matrix/) is a Python plugin for Weechat that lets Weechat communicate over the Matrix protocol.
|
|
|
|
|
|
|
|
# Project Status
|
|
|
|
|
2019-01-23 17:18:51 +01:00
|
|
|
Weechat-Matrix already supports large parts of the Matrix protocol, end to end encryption
|
|
|
|
support is still experimental.
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
# Installation
|
|
|
|
|
2019-05-22 23:02:21 +02:00
|
|
|
1. Install libolm 3.1+
|
2019-03-22 14:17:10 +01:00
|
|
|
|
2019-05-22 08:28:06 +02:00
|
|
|
- Debian/Ubuntu install libolm-dev if new enough
|
2019-03-22 14:17:10 +01:00
|
|
|
|
|
|
|
- Archlinux based distribution (see https://aur.archlinux.org/packages/libolm/)
|
|
|
|
use your favorite pacman frontend with AUR support (yaourt, yay, pikaur, …)
|
|
|
|
|
2019-05-22 08:28:06 +02:00
|
|
|
- Failing any of the above see https://git.matrix.org/git/olm
|
|
|
|
for instructions about building it from sources
|
|
|
|
|
2019-03-22 14:17:10 +01:00
|
|
|
2. Clone the repo and install dependencies
|
|
|
|
```
|
|
|
|
git clone https://github.com/poljar/weechat-matrix.git
|
|
|
|
cd weechat-matrix
|
|
|
|
pip install -r requirements.txt
|
|
|
|
```
|
|
|
|
|
|
|
|
3. As your regular user, just run: `make install` in this repository directory.
|
|
|
|
|
2019-09-03 13:32:19 +02:00
|
|
|
This installs the main python file (`main.py`) into
|
|
|
|
`~/.weechat/python/` (renamed to `matrix.py`) along with the other
|
|
|
|
python files it needs (from the `matrix` subdir).
|
|
|
|
|
2019-03-22 14:17:10 +01:00
|
|
|
Note that weechat only supports Python2 OR Python3, and that setting is
|
|
|
|
determined at the time that Weechat is compiled. Weechat-Matrix can work with
|
|
|
|
either Python2 or Python3, but when you install dependencies you will have to
|
|
|
|
take into account which version of Python your Weechat was built to use.
|
|
|
|
|
2019-06-27 19:53:59 +02:00
|
|
|
The minimal supported python2 version is 2.7.10.
|
|
|
|
|
2019-03-22 14:17:10 +01:00
|
|
|
To check the python version that weechat is using, run:
|
|
|
|
|
|
|
|
/python version
|
2019-01-24 17:15:37 +01:00
|
|
|
|
2019-09-03 13:31:55 +02:00
|
|
|
## Using virtualenv
|
|
|
|
If you want to install dependencies inside a virtualenv, rather than
|
|
|
|
globally for your system or user, you can use a virtualenv.
|
|
|
|
Weechat-Matrix will automatically use any virtualenv it finds in a
|
|
|
|
directory called `venv` next to its main Python file (after resolving
|
|
|
|
symlinks). Typically, this means `~/.weechat/python/venv`.
|
|
|
|
|
|
|
|
To create such a virtualenv, you can use something like below. This only
|
|
|
|
needs to happen once:
|
|
|
|
|
|
|
|
```
|
|
|
|
virtualenv ~/.weechat/python/venv
|
|
|
|
```
|
|
|
|
|
|
|
|
Then, activate the virtualenv:
|
|
|
|
|
|
|
|
```
|
|
|
|
. ~/.weechat/python/venv/bin/activate
|
|
|
|
```
|
|
|
|
|
|
|
|
This needs to be done whenever you want to install packages inside the
|
|
|
|
virtualenv (so before running the `pip install` command documented
|
|
|
|
above.
|
|
|
|
|
|
|
|
|
|
|
|
Once the virtualenv is prepared in the right location, Weechat-Matrix
|
|
|
|
will automatically activate it when the plugin is loaded. This should
|
|
|
|
not affect other plugins, which seem to have a separate Python
|
|
|
|
environment.
|
|
|
|
|
|
|
|
Note that this only supports virtualenv tools that support the
|
|
|
|
[`activate_this.py` way of
|
|
|
|
activation](https://virtualenv.pypa.io/en/latest/userguide/#using-virtualenv-without-bin-python).
|
|
|
|
This includes the `virtualenv` command, but excludes pyvenv and the
|
|
|
|
Python3 `venv` module. In particular, this works if (for a typical
|
|
|
|
installation of `matrix.py`) the file
|
|
|
|
`~/.weechat/python/venv/bin/activate_this.py` exists.
|
|
|
|
|
2019-09-03 13:45:36 +02:00
|
|
|
## Run from git directly
|
|
|
|
|
|
|
|
Rather than copying files into `~/.weechat` (step 3 above), it is also
|
|
|
|
possible to run from a git checkout directly using symlinks.
|
|
|
|
|
|
|
|
For this, you need two symlinks:
|
|
|
|
|
|
|
|
```
|
|
|
|
ln -s /path/to/weechat-matrix/main.py ~/.weechat/python/matrix.py
|
|
|
|
ln -s /path/to/weechat-matrix/matrix ~/.weechat/python/matrix
|
|
|
|
```
|
|
|
|
|
|
|
|
This first link is the main python file, that can be loaded using
|
|
|
|
`/script load matrix.py`. The second link is to the directory with extra
|
|
|
|
python files used by the main script. This directory must be linked as
|
|
|
|
`~/.weechat/python/matrix` so it ends up in the python library path and
|
|
|
|
its files can be imported using e.g. `import matrix` from the main python
|
|
|
|
file.
|
|
|
|
|
|
|
|
Note that these symlinks are essentially the same as the files that
|
|
|
|
would have been copied using `make install`.
|
|
|
|
|
2020-02-16 17:13:28 +01:00
|
|
|
## Uploading files
|
2019-01-24 17:15:37 +01:00
|
|
|
|
2020-02-16 17:13:28 +01:00
|
|
|
Uploads are done using a helper script, which is found under
|
|
|
|
[contrib/matrix_upload](https://github.com/poljar/weechat-matrix/blob/master/contrib/matrix_upload).
|
|
|
|
We recommend you install this under your `PATH`.
|
2018-04-09 05:43:04 +02:00
|
|
|
|
2020-02-16 17:13:28 +01:00
|
|
|
## Downloading encrypted files
|
2020-02-16 15:22:55 +01:00
|
|
|
|
2020-02-16 17:13:28 +01:00
|
|
|
Encrypted files can be opened by passing the displayed `emxc://` URI to the
|
|
|
|
[contrib/matrix_decrypt](https://github.com/poljar/weechat-matrix/blob/master/contrib/matrix_decrypt)
|
|
|
|
helper script.
|
2020-02-16 15:22:55 +01:00
|
|
|
|
2018-04-09 05:43:04 +02:00
|
|
|
# Configuration
|
|
|
|
|
|
|
|
Configuration is completed primarily through the Weechat interface. First start Weechat, and then issue the following commands:
|
|
|
|
|
|
|
|
1. Start by loading the Weechat-Matrix plugin:
|
|
|
|
|
2019-03-16 12:14:15 +01:00
|
|
|
/script load matrix.py
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
1. Now set your username and password:
|
|
|
|
|
2019-02-19 14:04:45 +01:00
|
|
|
/set matrix.server.matrix_org.username johndoe
|
|
|
|
/set matrix.server.matrix_org.password jd_is_awesome
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
1. Now try to connect:
|
|
|
|
|
2019-02-19 14:04:45 +01:00
|
|
|
/matrix connect matrix_org
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
1. If everything works, save the configuration
|
|
|
|
|
2019-01-23 22:02:19 +01:00
|
|
|
/save
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
## For using a custom (not matrix.org) matrix server:
|
|
|
|
|
|
|
|
1. Add your custom server to the plugin:
|
|
|
|
|
2019-01-23 22:02:19 +01:00
|
|
|
/matrix server add myserver myserver.org
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
1. Add the appropriate credentials
|
|
|
|
|
2019-01-23 22:02:19 +01:00
|
|
|
/set matrix.server.myserver.username johndoe
|
|
|
|
/set matrix.server.myserver.password jd_is_awesome
|
2018-04-09 05:43:04 +02:00
|
|
|
|
|
|
|
1. If everything works, save the configuration
|
|
|
|
|
2019-01-23 22:02:19 +01:00
|
|
|
/save
|
2018-04-09 05:43:04 +02:00
|
|
|
|
2019-09-11 14:02:00 +02:00
|
|
|
## Single sign-on:
|
|
|
|
|
|
|
|
Single sign-on is supported using a helper script, the script found under
|
|
|
|
[contrib/matrix_sso_helper](https://github.com/poljar/weechat-matrix/blob/master/contrib/matrix_sso_helper)
|
|
|
|
should be installed under your `PATH`.
|
|
|
|
|
|
|
|
For single sign-on to be the preferred leave the servers username and password
|
|
|
|
empty.
|
|
|
|
|
|
|
|
After connecting a URL will be presented which needs to be used to perform the
|
|
|
|
sign on. Please note that the helper script spawns a HTTP server which waits for
|
|
|
|
the sign-on token to be passed back. This makes it necessary to do the sign on
|
|
|
|
on the same host as Weechat.
|
2019-01-24 17:15:37 +01:00
|
|
|
|
2019-09-22 12:26:55 +02:00
|
|
|
A hsignal is sent out when the SSO helper spawns as well, the name of the
|
|
|
|
hsignal is `matrix_sso_login` and it will contain the name of the server in the
|
|
|
|
`server` variable and the full URL that can be used to log in in the `url`
|
|
|
|
variable.
|
|
|
|
|
|
|
|
To open the login URL automatically in a browser a trigger can be added:
|
|
|
|
|
|
|
|
/trigger add sso_browser hsignal matrix_sso_login "" "" "/exec -bg firefox ${url}"
|
|
|
|
|
2019-09-17 20:37:18 +02:00
|
|
|
If signing on on the same host as Weechat is undesirable the listening port of
|
|
|
|
the SSO helper should be set to a static value using the
|
|
|
|
`sso_helper_listening_port` setting:
|
|
|
|
|
|
|
|
/set matrix.server.myserver.sso_helper_listening_port 8443
|
|
|
|
|
|
|
|
After setting the listening port the same port on the local machine can be
|
|
|
|
forwarded using ssh to the remote host:
|
|
|
|
|
|
|
|
ssh -L 8443:localhost:8443 example.org
|
|
|
|
|
|
|
|
This forwards the local port 8443 to the localhost:8443 address on example.org.
|
|
|
|
Note that it is necessary to forward the port to the localhost address on the
|
|
|
|
remote host because the helper only listens on localhost.
|
|
|
|
|
2019-01-24 17:15:37 +01:00
|
|
|
## Bar items
|
|
|
|
|
|
|
|
There are two bar items provided by this script:
|
|
|
|
|
|
|
|
1. `matrix_typing_notice` - shows the currently typing users
|
|
|
|
|
|
|
|
1. `matrix_modes` - shows room and server info (encryption status of the room,
|
|
|
|
server connection status)
|
|
|
|
|
|
|
|
They can be added to the weechat status bar as usual:
|
|
|
|
/set weechat.bar.status.items
|
|
|
|
|
|
|
|
The `matrix_modes` bar item is replicated in the already used `buffer_modes` bar
|
|
|
|
item.
|
|
|
|
|
|
|
|
## Typing notices and read receipts
|
|
|
|
|
|
|
|
The sending of typing notices and read receipts can be temporarily disabled via
|
|
|
|
the `/room` command, they can also be permanently configured using standard
|
|
|
|
weechat conditions settings with the following settings:
|
|
|
|
|
|
|
|
1. `matrix.network.read_markers_conditions`
|
|
|
|
1. `matrix.network.typing_notice_conditions`
|
|
|
|
|
2018-04-09 05:43:04 +02:00
|
|
|
# Helpful Commands
|
|
|
|
|
|
|
|
`/help matrix` will print information about the `/matrix` command.
|
|
|
|
|
2019-01-23 17:18:51 +01:00
|
|
|
`/help olm` will print information about the `/olm` command that is used for
|
|
|
|
device verification.
|
|
|
|
|
2018-04-09 05:43:04 +02:00
|
|
|
`/matrix help [command]` will print information for subcommands, such as `/matrix help server`
|