Introduction

This is frontend web application for the Grassroots infrastructure using the Django framework. This application is open source and available from https://github.com/TGAC/grassroots_services_django_web.

Installation

Django is a Python-based framework so requires various Python components to be installed. These can be installed using

sudo apt install python3 virtualenv python3-pip

The next stage is to set up the virtual environment to run the application in which is done with the following commands:

virtualenv venv
source venv/bin/activate
pip install -r requirements.txt

Once this is done, then you need to set up the Django web application so that it has the correct paths for the Apache httpd server that is running Grassroots. This is done by creating a custom settings file to store the configuration details

cd grassroots_services_django_web
cp example_custom_settings.py custom_settings.py

In this file are the variables that you need to set up

  • STATIC_ROOT: The filesystem path to where the static files that Django uses will be installed and should be synchronized with the relative web address specified by the STATIC_URL variable listed below.
  • STATIC_URL: This is the web address to access the static files that are installed to the STATIC_ROOT path defined above.

So, for example if you have the Apache webserver's DocumentRoot variable set to /opt/apache/htdocs and you wish to have the Django static files served from /static, then these configuration variables would be:

STATIC_ROOT = '/opt/apache/htdocs/static'
STATIC_URL = '/static/'
  • SERVER_URL: This defines the web address of the Grassroots server that this Django application will be using.

Usage

To use this application, make sure that you are in the virtual environment by having run

source venv/bin/activate

After an initial install or after any changes to the static files, these need to be copied to the Apache webserver which can be done with:

python manage.py collectstatic

To run the application, the command is

python manage.py runserver <PORT>

where is the port that you wish to run the application on. For instance to run it on port 8000, the command would be:

python manage.py runserver 8000

So by browsing to http://localhost:<PORT>, or in the example above http://localhost:8000. you can access the application.