Python bindings for the Delta Chat Core library using CFFI against the Rust-implemented libdeltachat
Project description
This package provides bindings to the deltachat-core Rust -library which implements IMAP/SMTP/MIME/PGP e-mail standards and offers a low-level Chat/Contact/Message API to user interfaces and bots.
Installing pre-built packages (Linux-only)
If you have a Linux system you may try to install the deltachat binary “wheel” packages without any “build-from-source” steps. Otherwise you need to compile the Delta Chat bindings yourself.
We recommend to first install virtualenv, then create a fresh Python virtual environment and activate it in your shell:
virtualenv venv # or: python -m venv source venv/bin/activate
Afterwards, invoking python or pip install only modifies files in your venv directory and leaves your system installation alone.
For Linux, we automatically build wheels for all github PR branches and push them to a python package index. To install the latest github master branch:
pip install --pre -i https://m.devpi.net/dc/master deltachat
To verify it worked:
python -c "import deltachat"
Running tests
After successful binding installation you can install a few more Python packages before running the tests:
python -m pip install pytest pytest-xdist pytest-timeout pytest-rerunfailures requests pytest -v tests
This will run all “offline” tests and skip all functional end-to-end tests that require accounts on real e-mail servers.
running “live” tests with temporary accounts
If you want to run live functional tests you can set DCC_NEW_TMP_EMAIL to a URL that creates e-mail accounts. Most developers use https://testrun.org URLS created and managed by [mailadm](https://mailadm.readthedocs.io/en/latest/).
Please feel free to contact us through a github issue or by e-mail and we’ll send you a URL that you can then use for functional tests like this:
export DCC_NEW_TMP_EMAIL=<URL you got from us>
With this account-creation setting, pytest runs create ephemeral e-mail accounts on the http://testrun.org server. These accounts exists only for one hour and then are removed completely. One hour is enough to invoke pytest and run all offline and online tests:
pytest
# or if you have installed pytest-xdist for parallel test execution pytest -n6
Each test run creates new accounts.
Installing bindings from source (Updated: July 2020)
Install Rust and Cargo first. The easiest is probably to use rustup.
Bootstrap Rust and Cargo by using rustup:
curl https://sh.rustup.rs -sSf | sh
Then clone the deltachat-core-rust repo:
git clone https://github.com/deltachat/deltachat-core-rust cd deltachat-core-rust
To install the Delta Chat Python bindings make sure you have Python3 installed. E.g. on Debian-based systems apt install python3 python3-pip python3-venv should give you a usable python installation.
Ensure you are in the deltachat-core-rust/python directory, create the virtual environment and activate it in your shell:
cd python python3 -m venv venv # or: virtualenv venv source venv/bin/activate
You should now be able to build the python bindings using the supplied script:
python install_python_bindings.py
The core compilation and bindings building might take a while, depending on the speed of your machine. The bindings will be installed in release mode but with debug symbols. The release mode is currently necessary because some tests generate RSA keys which is prohibitively slow in non-release mode.
Code examples
You may look at examples.
Building manylinux based wheels
Building portable manylinux wheels which come with libdeltachat.so can be done with docker-tooling.
using docker pull / premade images
We publish a build environment under the deltachat/coredeps tag so that you can pull it from the hub.docker.com site’s “deltachat” organization:
$ docker pull deltachat/coredeps
This docker image can be used to run tests and build Python wheels for all interpreters:
$ docker run -e DCC_NEW_TMP_EMAIL \ --rm -it -v \$(pwd):/mnt -w /mnt \ deltachat/coredeps scripts/run_all.sh
Optionally build your own docker image
If you want to build your own custom docker image you can do this:
$ cd deltachat-core # cd to deltachat-core checkout directory $ docker build -t deltachat/coredeps scripts/docker_coredeps
This will use the scripts/docker_coredeps/Dockerfile to build up docker image called deltachat/coredeps. You can afterwards find it with:
$ docker images
Troubleshooting
On more recent systems running the docker image may crash. You can fix this by adding vsyscall=emulate to the Linux kernel boot arguments commandline. E.g. on Debian you’d add this to GRUB_CMDLINE_LINUX_DEFAULT in /etc/default/grub.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Hashes for deltachat-1.79.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 200cdb059c292d951a7e6ff14587ae6467ce2340268fa3db37135c20f8e86fbe |
|
MD5 | aae64666b4e90cbb98f18479b0fb2643 |
|
BLAKE2b-256 | bc624dd11bf9ed0399295568a49fa9da2b18dcc75b13fec876bc31227dc36a3b |
Hashes for deltachat-1.79.0-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f4a7d8384119da8be76abfc9d49f231ee0d895fefb6a21eb8ecfa69ecd62e76d |
|
MD5 | 295f31687f86ad1b60547de52ffe076d |
|
BLAKE2b-256 | 7bed8453672481a39033b527dc4e56bb0d3fcad7e1732aa69cdecfe2c3ff3324 |
Hashes for deltachat-1.79.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 814a698e1af8ad509a5454368906451bf3ad5af53898a8a2b99c98b44172f85f |
|
MD5 | 0a4fedfab8769f78b00359237f648668 |
|
BLAKE2b-256 | 23b1a12a1cf2da33a199abde199c743083f8a76935a5ac3003d19a9323e0e158 |
Hashes for deltachat-1.79.0-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 76ef8d13ea6480d6d4fa47d59a64c817e9a1c749d18e5bac613ec80b484bdebe |
|
MD5 | f2890436df74969f1bf4d101e2a94871 |
|
BLAKE2b-256 | c5d56fd81f302aaefc271e0f07a3c1fb35fa1aecf589e21dfd606470d3e8c9c6 |
Hashes for deltachat-1.79.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 904c0c19556586c713d0bd869f87a0b784ebf14be0d597b3e61bdaac38559546 |
|
MD5 | 320970d965b5ed511ac43b98a856f047 |
|
BLAKE2b-256 | 92ff7ff0caecfed51f81aae1b6e95c3a29dc5f23b898b75b5b84f6c531d36e01 |
Hashes for deltachat-1.79.0-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0dee57066aa88fae0d46c2f91113db1f98d76704ddab01b58d1e669af519966a |
|
MD5 | 7a88e348c81e66701f9f9916566938c6 |
|
BLAKE2b-256 | 395b6eb2f6c89e30bb871ae1d07f1858b49ea5831a4f4ab600d0a097c80cf2eb |