2016-10-04 22:26:37 +00:00
.. _install:
2013-08-07 19:35:12 +00:00
Installing poezio
2013-04-08 16:52:35 +00:00
=================
2018-08-13 20:38:01 +00:00
.. warning :: Python 3.5 or above is **required** .
2014-11-29 17:10:04 +00:00
To install it on a distribution that doesn't provide it, see :ref: `pyenv <pyenv-install>` .
2013-04-08 16:52:35 +00:00
2013-08-07 19:35:12 +00:00
poezio in the GNU/Linux distributions
2013-04-08 16:52:35 +00:00
-------------------------------------
As far as I know, Poezio is available in the following distributions, you just
have to install it by using the package manager of the distribution, if you're
using one of these.
2016-10-09 12:37:34 +00:00
- **Archlinux** : poezio_ and poezio-git_ packages are in the AUR
(use your favourite AUR wrapper to install them)
2019-09-02 17:12:19 +00:00
- **Gentoo** : `net-im/poezio`_
2015-02-28 20:08:17 +00:00
- **Fedora** : The stable poezio package was out of date for a long time in
Fedora, but now thanks to Casper, there is an `up-to-date package`_ in
the repos since F19.
2018-08-15 12:38:27 +00:00
- **Debian** : A stable package is provided since buster_ thanks to debacle.
2015-08-14 19:30:54 +00:00
- **Nix** (and **NixOS** ): The last stable version of poezio is availalble in
the unstable branch of `nixpkgs` . Use `` nix-env -f "<nixpkgs>" -iA poezio ``
to install poezio for the current user.
2016-10-09 12:37:34 +00:00
- **OpenBSD** : a poezio port_ is available
2013-04-08 16:52:35 +00:00
2014-02-18 23:39:51 +00:00
(If another distribution provides a poezio package, please tell us and we will
2013-08-07 19:35:12 +00:00
add it to the list)
2013-04-08 16:52:35 +00:00
2018-08-11 20:53:47 +00:00
Thank to all the maintainers who took time to make and maintain those packages!
2014-02-19 00:20:15 +00:00
Install from source
-------------------
2013-04-08 16:52:35 +00:00
2014-02-18 23:39:51 +00:00
Stable version
~~~~~~~~~~~~~~
2013-04-08 16:52:35 +00:00
2014-11-04 20:16:47 +00:00
`Stable version`_ packages are available in standalone (dependencies provided)
2014-02-19 00:20:15 +00:00
and poezio-only packages (both with prebuilt html doc for convenience).
2013-04-08 16:52:35 +00:00
2014-11-04 20:16:47 +00:00
Those versions are also available on pypi_ (using pip3, for example), and it is
recommended to install them this way if you absolutely want to **install** poezio
and your distribution provides no package.
2013-04-08 16:52:35 +00:00
2014-02-18 23:39:51 +00:00
Development version
~~~~~~~~~~~~~~~~~~~
2013-04-08 16:52:35 +00:00
2014-02-18 23:39:51 +00:00
The stable versions of poezio are more like snapshots of states of
development we deem acceptable. There is always an incentive to
use the development version, like new features, bug fixes, and more
support. Therefore, you might want to use the git version.
2013-04-08 16:52:35 +00:00
.. code-block :: bash
2019-02-14 15:19:11 +00:00
git clone https://lab.louiz.org/poezio/poezio
2014-02-18 23:39:51 +00:00
cd poezio
2013-04-08 16:52:35 +00:00
2014-02-18 23:39:51 +00:00
"""""""
General
"""""""
2013-04-08 16:52:35 +00:00
2018-08-13 20:38:01 +00:00
Poezio is a python3.5 (and above)-only application, so you will first need that.
2013-04-08 16:52:35 +00:00
2015-09-29 22:34:29 +00:00
Packages required for building poezio and deps:
- make
- gcc
- libidn and libidn-dev, only if you want to use cython_ (see below)
- python3-devel (or equivalent)
- python3-setuptools
2020-01-18 22:47:10 +00:00
- python3-pip
- python3-venv
- libffi-dev (for pycares, needed by slixmpp)
- pyasn1 and pyasn1-modules (needed by slixmpp)
On Debian, you can install the dependencies as follows:
.. code-block :: bash
apt install python3-dev make gcc python3-setuptools python3-pip python3-venv libffi-dev
pip3 install --user pyasn1 pyasn1-modules
2015-09-29 22:34:29 +00:00
Then you can run `` make `` to build it the poezio C extension module.
2014-11-04 20:16:47 +00:00
If you downloaded the standalone stable package, you are finished here and can skip
to :ref: `running poezio <poezio-run-label>` .
2013-04-08 16:52:35 +00:00
2015-09-29 22:34:29 +00:00
Poezio needs two libraries to run:
2013-04-08 16:52:35 +00:00
2014-11-04 20:16:47 +00:00
- aiodns_
- slixmpp_
2015-09-05 12:12:01 +00:00
- slixmpp can make use of cython_ to compile performance-critical modules and be faster
2014-11-04 20:16:47 +00:00
.. versionchanged :: 0.9
2014-02-18 23:39:51 +00:00
2014-10-27 18:16:32 +00:00
2015-02-28 20:08:17 +00:00
.. note :: We provide an `` update.sh `` script that creates a virtualenv and
2014-11-04 20:16:47 +00:00
downloads all the required and optional dependencies inside it.
we recommend using it with the git version of poezio, in order
to keep everything up-to-date.
2014-02-18 23:39:51 +00:00
2014-11-04 20:16:47 +00:00
If you don’ t want to use the update script for whatever reason, install the
following dependencies by hand; otherwise, skip to the
2014-11-29 17:10:04 +00:00
:ref: `installation part <poezio-install-label>` .
2014-02-18 23:39:51 +00:00
2014-11-04 20:16:47 +00:00
""""""""
slixmpp
""""""""
2015-09-29 22:34:29 +00:00
Poezio depends on slixmpp, a non-threaded fork of the SleekXMPP library.
2013-04-08 16:52:35 +00:00
.. code-block :: bash
2019-02-14 15:19:11 +00:00
git clone https://lab.louiz.org/poezio/slixmpp
2014-02-18 23:39:51 +00:00
python3 setup.py install --user
2013-04-08 16:52:35 +00:00
2014-11-04 20:16:47 +00:00
""""""
aiodns
""""""
2015-09-29 22:34:29 +00:00
The aiodns library is required in order to properly resolve XMPP domains (with SRV records).
2014-11-04 20:16:47 +00:00
2013-04-08 16:52:35 +00:00
.. code-block :: bash
2020-01-15 16:38:39 +00:00
pip3 install --user aiodns
2014-11-04 20:16:47 +00:00
This will also install pycares, which aiodns uses.
2014-02-18 23:39:51 +00:00
2013-04-08 16:52:35 +00:00
2015-02-28 20:08:17 +00:00
""""""""
Building
""""""""
If you don’ t run the `` update.sh `` script, you need to manually build the C
module used by poezio:
.. code-block :: bash
make
2013-04-08 16:52:35 +00:00
.. _poezio-install-label:
2014-02-18 23:39:51 +00:00
Installation
~~~~~~~~~~~~
2013-04-08 16:52:35 +00:00
2013-08-07 19:35:12 +00:00
.. note ::
The update.sh + launch.sh method is the recommended way of using and upgrading
2014-02-18 23:39:51 +00:00
the devel version of poezio. Installing should only be done with stable versions.
2014-11-04 20:16:47 +00:00
And preferably using your distribution’ s package manager.
2013-08-07 19:35:12 +00:00
2014-02-18 23:39:51 +00:00
If you skipped the installation of the dependencies and you only want to run
poezio without a system-wide install, do, in the :file: `poezio` directory:
2013-04-08 16:52:35 +00:00
.. code-block :: bash
./update.sh
2015-09-05 12:12:01 +00:00
.. note ::
You should probably install cython (for python3) on your system using your
package manager, since the installation from pypi takes a long time.
2015-01-24 16:54:30 +00:00
.. note ::
If you want to use a custom directory for the virtualenv used by poezio,
you can use the `` $POEZIO_VENV `` environment variable to set use
another path (the default is :file: `poezio-venv` ).
2017-10-06 21:47:42 +00:00
.. note ::
The python version used can be customized using the `` $POEZIO_PYTHON ``
env variable.
If your distribution's python3 does not have a `` venv `` module, install
the package corresponding to that module (probably `` python3-venv `` ).
.. versionchanged :: 0.12
Previously there was a `` $POEZIO_VENV_COMMAND `` env variable to define
the command. Now it is required to use `` $POEZIO_PYTHON `` .
2015-01-24 16:54:30 +00:00
2014-11-04 20:16:47 +00:00
If you really want to install it, run as root (or sudo in ubuntu or whatever):
2013-04-08 16:52:35 +00:00
.. code-block :: bash
2014-02-19 00:20:15 +00:00
make install
2013-04-08 16:52:35 +00:00
2014-02-18 23:39:51 +00:00
2014-02-19 00:20:15 +00:00
.. _poezio-run-label:
Running
~~~~~~~
If you didn’ t install poezio, you can run it from the source directory
with:
2013-04-08 16:52:35 +00:00
.. code-block :: bash
2014-02-19 00:20:15 +00:00
./launch.sh
2013-04-08 16:52:35 +00:00
2015-02-28 20:08:17 +00:00
If you did, it should be in the `` $PATH `` as `` poezio `` , so run:
2013-04-08 16:52:35 +00:00
.. code-block :: bash
poezio
2016-10-15 17:10:33 +00:00
Docker images
-------------
poezio is available on the docker hub in the `poezio/poezio`_ repository
in which `` poezio/poezio:latest `` is the latest built git version, and
stable versions are tagged with their numbers. The image is based off
alpine linux and we tried to keep the image size to a minimum (<100MiB).
You can therefore just fetch the images with docker pull:
.. code-block :: bash
docker pull poezio/poezio
In order to run poezio with non-temporary config and logs, and to have
2018-08-11 20:53:47 +00:00
the right colors, you have to share the `` TERM `` env var and some directories
that should be created beforehand:
2016-10-15 17:10:33 +00:00
.. code-block :: bash
2018-08-11 20:53:47 +00:00
mkdir -p ~/.config/poezio ~/.local/share/poezio
2016-10-15 17:10:33 +00:00
docker run -it -e TERM -v ~/.config/poezio:/home/poezio-user/.config/poezio -v ~/.local/share/poezio:/home/poezio-user/.local/share/poezio poezio/poezio
If you don’ t trust images distributed on the docker hub, you can rebuild the
image from the Dockerfile at the root of the git repository.
2013-04-08 16:52:35 +00:00
.. _stable sources: https://dev.louiz.org/project/poezio/download
2014-11-04 20:16:47 +00:00
.. _slixmpp: https://dev.louiz.org/projects/slixmpp
.. _aiodns: https://github.com/saghul/aiodns
2013-08-07 19:35:12 +00:00
.. _poezio: https://aur.archlinux.org/packages/poezio/
.. _poezio-git: https://aur.archlinux.org/packages/poezio-git/
2014-02-18 23:39:51 +00:00
.. _up-to-date package: https://apps.fedoraproject.org/packages/poezio
2014-11-04 20:16:47 +00:00
.. _pypi: https://pypi.python.org/pypi/poezio
2015-09-05 12:12:01 +00:00
.. _cython: http://cython.org
2016-10-09 12:37:34 +00:00
.. _bgo-overlay: https://bgo.zugaina.org/
.. _port: http://ports.su/net/poezio
2016-10-15 17:10:33 +00:00
.. _poezio/poezio: https://hub.docker.com/r/poezio/poezio/
2018-08-15 12:38:27 +00:00
.. _buster: https://packages.debian.org/buster/poezio
2019-09-02 17:12:19 +00:00
.. _net-im/poezio: https://packages.gentoo.org/packages/net-im/poezio