2019-03-25 09:12:36 -04:00
|
|
|
pantalaimon
|
|
|
|
===========
|
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
Pantalaimon is an end-to-end encryption aware Matrix reverse proxy daemon.
|
2019-05-24 16:34:05 -04:00
|
|
|
Pantalaimon acts as a good man in the middle that handles the encryption for you.
|
2019-05-24 07:48:51 -04:00
|
|
|
|
|
|
|
Messages are transparently encrypted and decrypted for clients inside of
|
|
|
|
pantalaimon.
|
2019-03-25 09:12:36 -04:00
|
|
|
|
2019-05-24 16:28:37 -04:00
|
|
|
![Pantalaimon in action](docs/pan.gif)
|
2019-03-28 12:07:10 -04:00
|
|
|
|
2019-03-30 06:42:47 -04:00
|
|
|
Installation
|
2019-05-24 07:48:51 -04:00
|
|
|
============
|
2019-03-28 12:07:10 -04:00
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
The [Olm](https://gitlab.matrix.org/matrix-org/olm) C library is required to
|
|
|
|
be installed before installing pantalaimon.
|
2019-03-28 12:07:10 -04:00
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
If your distribution provides packages for libolm it is best to use those, note
|
|
|
|
that a recent version of libolm is required (3.1+). If your distribution doesn't
|
|
|
|
provide a package building from source is required. Please refer to the Olm
|
|
|
|
[readme](https://gitlab.matrix.org/matrix-org/olm/blob/master/README.md)
|
|
|
|
to see how to build the C library from source.
|
|
|
|
|
|
|
|
Installing pantalaimon works like usually with python packages:
|
2019-03-28 12:07:10 -04:00
|
|
|
|
|
|
|
python setup.py install
|
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
Pantalaimon can also be found on pypi:
|
|
|
|
|
|
|
|
pip install pantalaimon
|
|
|
|
|
2019-07-26 07:42:29 -04:00
|
|
|
Pantalaimon contains a dbus based UI that can be used to controll the daemon.
|
|
|
|
The dbus based UI is completely optional and needs to be installed with the
|
|
|
|
daemon:
|
|
|
|
|
|
|
|
pip install pantalaimon[ui]
|
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
Do note that man pages can't be installed with pip.
|
|
|
|
|
2019-05-24 11:09:12 -04:00
|
|
|
### macOS installation
|
|
|
|
|
|
|
|
For instance, on macOS, this means:
|
|
|
|
|
|
|
|
```bash
|
2019-05-24 11:53:57 -04:00
|
|
|
brew install dbus
|
2019-05-24 12:41:37 -04:00
|
|
|
perl -pi -e's#(<auth>EXTERNAL</auth>)#<!--$1-->#' $(brew --prefix dbus)/share/dbus-1/session.conf
|
2019-05-24 11:53:57 -04:00
|
|
|
brew services start dbus
|
|
|
|
# it may be necessary to restart now to get the whole OS to pick up the
|
|
|
|
# existence of the dbus daemon
|
|
|
|
|
2019-05-24 11:09:12 -04:00
|
|
|
git clone https://gitlab.matrix.org/matrix-org/olm
|
|
|
|
(cd olm; make)
|
|
|
|
git clone https://github.com/matrix-org/pantalaimon
|
|
|
|
(cd pantalaimon; CFLAGS=-I../olm/include LDFLAGS=-L../olm/build/ python3 setup.py install)
|
2019-05-24 11:53:57 -04:00
|
|
|
|
|
|
|
export DBUS_SESSION_BUS_ADDRESS=unix:path=$(launchctl getenv DBUS_LAUNCHD_SESSION_BUS_SOCKET)
|
2019-05-24 12:41:37 -04:00
|
|
|
cd pantalaimon
|
|
|
|
DYLD_LIBRARY_PATH=../olm/build/ pantalaimon -c contrib/pantalaimon.conf
|
|
|
|
|
|
|
|
# for notification center:
|
|
|
|
git clone https://github.com/fakechris/notification-daemon-mac-py
|
|
|
|
# if you have django's `foundation` library installed and your filesystem
|
|
|
|
# is case insensitive (the default) then you will need to `pip uninstall foundation`
|
|
|
|
# or install PyObjC in a venv...
|
|
|
|
pip install PyObjC daemon glib dbus-python
|
|
|
|
cd notification-daemon-mac-py
|
|
|
|
./notify.py
|
2019-05-24 11:09:12 -04:00
|
|
|
```
|
|
|
|
|
2019-07-03 11:46:04 -04:00
|
|
|
### Experimental E2E search support.
|
|
|
|
|
|
|
|
Pantalaimon can handle the search endpoint of a Matrix server as well, providing
|
|
|
|
search support for E2E encrypted rooms.
|
|
|
|
|
|
|
|
For this to work [tantivy](https://github.com/tantivy-search/tantivy) is needed.
|
|
|
|
Tantivy is a full text search engine written in rust.
|
|
|
|
|
|
|
|
The python bindings for tantivy are needed for pantalaimon. The bindings are not
|
|
|
|
yet merged upstream, instead they can be found
|
|
|
|
[here](https://github.com/matrix-org/tantivy/tree/topcollector_order_by/python).
|
|
|
|
|
|
|
|
Note that rust nightly (tested version was: 1.36.0-nightly (50a0defd5 2019-05-21))
|
|
|
|
and [setuptools-rust](https://pypi.org/project/setuptools-rust/) are required
|
|
|
|
before the tantivy python bindings can be installed.
|
|
|
|
|
2019-03-28 12:07:10 -04:00
|
|
|
Usage
|
|
|
|
=====
|
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
While pantalaimon is a daemon, it is mean to be run as your own user. It won't
|
|
|
|
verify devices for you automatically, unless configured to do so, and requires
|
|
|
|
user interaction to verify, ignore or blacklist devices.
|
|
|
|
|
|
|
|
Pantalaimon requires a configuration file to run. The configuration file
|
|
|
|
specifies one or more homeservers for pantalaimon to connect to.
|
2019-03-28 12:07:10 -04:00
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
A minimal pantalaimon configuration looks like this:
|
|
|
|
```dosini
|
|
|
|
[local-matrix]
|
|
|
|
Homeserver = https://localhost:8448
|
|
|
|
ListenAddress = localhost
|
|
|
|
ListenPort = 8009
|
|
|
|
```
|
2019-03-28 12:07:10 -04:00
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
The configuration file should be placed in `~/.config/pantalaimon/pantalaimon.conf`.
|
|
|
|
|
|
|
|
The full documentation for the pantalaimons configuration can be found in
|
|
|
|
the man page `pantalaimon(5)`.
|
|
|
|
|
|
|
|
Now that pantalaimon is configured it can be run:
|
|
|
|
|
|
|
|
pantalaimon --log-level debug
|
|
|
|
|
|
|
|
After running the daemon, configure your client to connect to the daemon instead
|
2019-03-28 12:07:10 -04:00
|
|
|
of your homeserver. The daemon listens by default on localhost and port 8009.
|
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
Note that logging in to the daemon is required to start a sync loop for a user.
|
|
|
|
After that clients can connect using any valid access token for the user that
|
|
|
|
logged in. Multiple users per homeserver are supported.
|
|
|
|
|
|
|
|
For convenience a systemd service file is provided.
|
|
|
|
|
|
|
|
To control the daemon an interactive utility is provided in the form of
|
|
|
|
`panctl`.
|
2019-03-28 12:07:10 -04:00
|
|
|
|
2019-05-24 07:48:51 -04:00
|
|
|
`panctl` can be used to verify, blacklist or ignore devices, import or export
|
|
|
|
session keys, or to introspect devices of users that we share encrypted rooms
|
|
|
|
with.
|