Racine is a tool that enables researchers to keep track of their samples from any PC in a laboratory. It is a Flask-based web service that runs on a central server in the local network of your research institute and that can be accessed from all other computers on the same network using the normal web browser.
- open source software
- central data storage on a server in your lab
- simple interface in your web browser
- easy to set up using a pre-built docker image
- hierarchical sample ordering
- sample sharing between users
- dated entries (actions) that can only be edited by the creator
- image and attachment upload
- image import from SMB servers
- LaTeX type setting
- print summaries for specific samples or time periods
The developers take no responsibility for the loss or theft of data managed by this software. The software sends anonymous usage statistics to the developers, including the software version, the number of users, samples and actions stored in the database, the server uptime and the used/available disk space.
mkdir racine && cd racine
wget hgrf.github.io/racine/docker-compose.yml
docker compose up
If you want to use SSL, add the certificate server.crt
and key server.key
in the folder
racine/ssl
. Also create a file server_name.txt
which contains the server name.
Create the file /etc/systemd/system/racine.service
with the following content:
[Unit]
Description=Service for Racine
Requires=docker.service
After=docker.service
[Service]
Type=oneshot
WorkingDirectory=<path to racine directory>
Environment=COMPOSE_HTTP_TIMEOUT=600
ExecStart=/usr/bin/env /usr/bin/docker compose -f <path to racine directory>/docker-compose.yml up -d
ExecStop=/usr/bin/env /usr/bin/docker compose -f <path to racine directory>/docker-compose.yml stop
StandardOutput=syslog
RemainAfterExit=yes
[Install]
WantedBy=multi-user.target
Then run:
systemctl daemon-reload
systemctl enable racine
systemctl start racine
The latest Racine desktop application can be downloaded from the Releases page. This demo application saves all data locally and can be used to get an idea of Racine's features and to take notes for yourself.
This programme should work an almost any platform (Linux, Windows, MacOS), but I only provide the installation instructions for Linux. Seeing that you should install it on a server, I suppose Linux is the target OS in most cases anyways.
You should have python 3.x and python3-venv installed on your system. Using a virtual environment is not absolutely necessary, but I recommend it. You can now create a folder somewhere and clone the git repository:
git clone [email protected]:hgrf/racine.git
Now you enter this directory and you create a virtual environment for python - and activate it:
cd racine
python3 -m venv venv
. venv/bin/activate
Finally, all that remains to do is to install the required python packages and JavaScript dependencies:
make app-deps app-dev-deps
make js-build
Now you have to initialise the database by running:
flask db upgrade
Note that, if you want to initialise the database for deployment (i.e. in the "production" configuration), you should first set up the FLASK_CONFIG variable accordingly:
export FLASK_CONFIG=production && flask db upgrade
This will also create the admin user that you will use for your first login ([email protected], password is admin).
You can update the details (user name, email and password) of the administrator in the "Profile" section (you will find the corresponding button on the top right after logging in). Also remember to set up an email account in the corresponding subsection of the "Settings" page.
You can set up a site name for usage statistics by writing it into a file "usage_stats_site" in the data folder.
You can start the development server by simply executing:
make run-no-docker
Install Docker, see https://docs.docker.com/engine/install/ubuntu/
Build and run:
make build-dev
make run-dev
make build
make run
In order to auto-correct coding style, use:
make black
In order to run this as a pre-commit hook, use:
pre-commit install
Tested in Ubuntu 22.04:
make desktop-dist
The software (in desktop/dist/
) can then be started using:
./RacineDesktop-0.1.0.AppImage
Debugging both the Flask backend and the Electron frontend can be activated as follows:
FLASK_ENV=development ./RacineDesktop-0.1.0.AppImage
- https://github.com/matbloch/electron-flask
- https://medium.com/red-buffer/integrating-python-flask-backend-with-electron-nodejs-frontend-8ac621d13f72
- https://www.npmjs.com/package/generator-electron-flask/v/1.0.8
wget https://github.com/nektos/act/releases/latest/download/act_Linux_x86_64.tar.gz
tar xvf act_Linux_x86_64.tar.gz act
rm act_Linux_x86_64.tar.gz
./act -j build-appimage
Carry out the steps described above in order to set up the development server. Then configure gunicorn autostart by setting up a corresponding autostart file. This is explained below either for upstart or for systemd.
Please note that the app should be executed in the HTTP root, bugs should be expected when you install Racine in a subfolder.
Note the use of the --preload
option for gunicorn in the following, which ensures that the thread
for reporting usage statistics is only started once (before the worker processes are forked). Also
note that you can test the multiprocessing behaviour in your development environment by running
e.g.:
gunicorn [--preload] --workers 4 --bind 127.0.0.1 manage:app
Create the file /etc/init/racine.conf and copy the following code into it:
description "Gunicorn application server running Racine"
start on runlevel [2345]
stop on runlevel [!2345]
respawn
setuid [user name]
setgid www-data
env FLASK_CONFIG=production
env PATH=[path]/racine/venv/bin:/usr/bin
chdir [path]/racine
exec gunicorn --preload --workers 4 --bind unix:racine.sock -m 007 manage:app
Where you will have to replace [user name] by your user name and [path] by the path where you installed the programme. The second path (/usr/bin) is where you should have installed the git executable.
Create the file /lib/systemd/system/racine.service and copy the following code into it:
[Unit]
Description=Gunicorn application server running Racine
[Service]
Restart=on-failure
User=[user name]
Group=www-data
Environment=FLASK_CONFIG=production
Environment=PATH=[path]/racine/venv/bin:/usr/bin
WorkingDirectory=[path]/racine
ExecStart=[path]/racine/venv/bin/gunicorn --preload --workers 4 --bind unix:racine.sock -m 007 manage:app
[Install]
WantedBy=multi-user.target
Where you will have to replace [user name] by your user name and [path] by the path where you installed the programme. The second path (/usr/bin) is where you should have installed the git executable.
Note that for the execution of gunicorn, the group has to be set to www-data
so that the
racine.sock
file is accessible for the nginx server (this also applies to the upstart configuration
above).
Now activate autostart:
sudo systemctl enable racine
Now install nginx:
sudo apt-get install nginx
Create an SSL certificate and key in the following folder:
sudo mkdir /etc/nginx/ssl
cd /etc/nginx/ssl
In order to create SSL certificate and key follow the steps given in https://www.digitalocean.com/community/tutorials/how-to-create-a-ssl-certificate-on-nginx-for-ubuntu-12-04
You then want to configure your nginx server. Create a file "racine" in /etc/nginx/sites-available and copy the following content into it:
server {
listen 80;
server_name localhost;
rewrite ^ https://$server_name$request_uri? permanent;
}
# HTTPS server
server {
listen 443;
server_name localhost;
ssl on;
ssl_certificate /etc/nginx/ssl/server.crt;
ssl_certificate_key /etc/nginx/ssl/server.key;
location / {
include proxy_params;
proxy_pass http://unix:[path]/racine/racine.sock;
}
}
Where - again - you have to replace [path] by the path to the application's directory. Then create a symbolic link to this file in /etc/nginx/sites-enabled and delete the default entry:
sudo ln -s /etc/nginx/sites-available/racine /etc/nginx/sites-enabled
sudo rm /etc/nginx/sites-enabled/default
If you want your server to support large file uploads, you have to change /etc/nginx/nginx.conf and add the following line to the http context to increase the size limit (in this example 5 Megabytes):
# set client body size to 5M #
client_max_body_size 5M;
You can now start your server by executing:
sudo start racine
sudo service nginx restart
If you use upstart, for systemd type:
sudo systemctl start racine
sudo systemctl restart nginx
The server will now automatically - i.e. also after a reboot - be available on localhost.
More details: https://www.digitalocean.com/community/tutorials/how-to-serve-flask-applications-with-gunicorn-and-nginx-on-ubuntu-14-04
- update RACINE_VERSION (and, if applicable RACINE_API_VERSION) in version.csv
- update CHANGELOG.md
make js-version
to update the version number of the JS librarygit checkout -b release
to create a branch for a subsequent PR (this enables to run all CI checks, build and deployment before merging to master)git commit -m "Release vX.Y.Z"
git push --tags -u origin release
- create a PR for this branch; if all checks pass, it may be merged
- pull master and
git tag vX.Y.Z
, then push tag make website-prepare-deploy
- commit and push changes to
docker-compose.yml
- update release notes (with changelog) on GitHub
- for new patch versions "vX.Y.Z", update the documentation tag "vX.Y.x" if it exists, or create that tag and activate the corresponding version on https://readthedocs.org/projects/racine/versions