Installation
SENAITE is an Add-on for the Plone Content Management Framework and the installation instructions depend therefore mostly on the successful installation of Plone.
Operating system
We recommend to install SENAITE on Ubuntu or Debian Linux. Installation on MacOS works as well, but needs additional packages installed via Homebrew.
In this secion we will mostly use Ubuntu 18.04 LTS as reference system.
The installation on other Linux distributions, MacOS or Windows is not covered here.
A note about Versions
The current codebase of SENAITE is at the moment only compatible with the latest version 4 of Plone.
☝️Note: This version of Plone works only with Python 2.x.
Python
Most UNIX based operating system (Linux/Mac OSX) ship already with a Python interpreter installed. However, it is not recommended to use the system interpreter to setup and install SENAITE on the local system.
Besides the required super-user permissions for installing additional Python libraries is that it might get upgraded by the system and get incompatible.
Therefore, it is better to setup a virtual Python environment with one of the following tools:
- Virtualenv: https://pypi.org/project/virtualenv
- Miniconda: https://conda.io/miniconda.html
In this manual we will use Miniconda.
Create a new User
Create a new user senaite in your system with the following command:
$ sudo adduser --home /home/senaite --shell /bin/bash senaite
And make sure you became this user within the following sections:
$ sudo su - senaite
$ whoami
senaite
Miniconda
Download and install the Python 2.7 version for your operating system:
$ wget https://repo.anaconda.com/miniconda/Miniconda2-latest-Linux-x86_64.sh
$ bash /home/senaite/Miniconda2-latest-Linux-x86_64.sh
$ source /home/senaite/.bashrc
You can accept the default settings of the miniconda installer
Create a new Python environment with the name senaite:
$ conda create --name senaite python=2.7
Activate the Python environment:
$ conda activate senaite
The command which python can be used to check if the right Python interpreter
is active in the current session:
$ which python
/home/senaite/miniconda2/envs/senaite/bin/python
$ python
Python 2.7.17 |Anaconda, Inc.| (default, Oct 21 2019, 19:04:46)
[GCC 7.3.0] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>>
Install System dependencies
Install the required dependencies for SENAITE:
$ sudo apt install build-essential
$ sudo apt install python2.7 python2.7-dev
$ sudo apt install libxml2 libxml2-dev libxslt1.1 libxslt1-dev
$ sudo apt install libffi-dev libcairo2 libpango-1.0-0 libgdk-pixbuf2.0-0 libpangocairo-1.0-0 libgdk-pixbuf2.0-0
Download the Plone unified installer
The Plone Unified Installer installs Plone and its dependencies from source on most Unix-like platforms.
$ wget --no-check-certificate https://launchpad.net/plone/4.3/4.3.19/+download/Plone-4.3.19-UnifiedInstaller.tgz
$ tar xzf Plone-4.3.19-UnifiedInstaller.tgz
$ cd Plone-4.3.19-UnifiedInstaller
Install Plone
Next step is to install Plone with the provided install.sh shell script:
$ ./install.sh standalone --target=/home/senaite --instance=senaitelims --password=admin
☝️Note:
We install SENAITE in the directory /home/senaite/senaitelims and we have set
the admin password to admin
Install SENAITE
To install SENAITE we need to modify the generated buildout.cfg config file.
Buildout is an automation tool written in and extended with Python:
$ cd /home/senaite/senaitelims
$ vim buildout.cfg
☝️Note:
You can use nano or any other text editor you feel comfortable with
Add senaite.lims to the eggs section of the file:
[buildout]
...
eggs =
    ...
    senaite.lims
zcml =
...
[versions]
zc.buildout =
setuptools =
☝️Note:
The version unpinning of zc.buildout and setuptools is important!
Upgrade pip, setuptools and zc.buildout
We need to ensure that pip, setuptools, and zc.buildout are available in a
compatible version:
Create a requirements.txt file:
$ cd /home/senaite/senaitelims
$ cat << EOF > requirements.txt
setuptools==39.2.0
zc.buildout==2.13.2
pip==19.3.1
EOF
Install the requirements with the pip command of the local Python environment:
$ which pip
/home/senaite/miniconda2/envs/senaite/bin/pip
$ pip install -r requirements.txt
☝️Note:
A wrong version of setuptools can lead to the infamous
Error while buildout: There is a version conflict. We already have: UNKNOWN 0.0.0
Re-run the buildout script:
$ which buildout
/home/training/miniconda2/envs/senaite/bin/buildout
$ PYTHONHTTPSVERIFY=0 buildout
Further links
- https://github.com/senaite/senaite.lims#readme
- http://www.buildout.org/en/latest/
- https://setuptools.readthedocs.io/en/latest
- https://docs.conda.io/en/latest/miniconda.html
Starting SENAITE
After the buildout command of the previous step returned without errors, you
can start SENAITE from the terminal.
To start SENAITE in foreground (debug) mode, use this command:
$ bin/instance fg
To stop the server, you can press CTRL+C on your keyboard.
Note
You can also start SENAITE in the background (production) mode with the command
bin/instance start and stop it again with bin/instance stop.
This will print several logs to the terminal and notifies when the server is ready with the line:
2019-09-14 09:59:44 INFO Zope Ready to handle requests
Open a browser (Safari/Chrome/FireFox ...) and navigate to the URL http://localhost:8080

Log in with admin:admin to proceed to the next page.

You can continue with the default settings and press the Install SENAITE LIMS button. After a few moments, SENAITE should be installed and the dashboard view appears.

Congratulations 🙌 you successfully installed SENAITE LIMS on your system!
Please continue with the next sections to learn the first steps in your new system.