The aim of this project is to facilitate an enhanced web interface for radio galaxy zoo (Banfield+) allowing users to label galaxy data suggested by an active learning backend (Acton). This project currently builds upon the django framework.
For a multithreaded version of this code, see the multi-threaded branch.
User documentation can be found on the wiki (https://github.com/ADACS-Australia/SS18A-JBanfield/wiki).
- Python 3
- MySQL 5.7+ (tested with 5.7)
Optional
- Docker and Docker-Compose
The required steps include the following:
virtualenv venv
(create the virtual environment, e.g. with https://docs.python.org/3/library/venv.html or https://github.com/pyenv/pyenv)git pull
(clone the code)source venv/bin/activate
(activate the virtual environment)cd zooniverse/zooniverse/settings
(enter the settings directory)touch local.py
(create the file for local settings - refer to the Local Settings section for setting up a local settings file)cd ../../
(enter the root directory of the project)pip3 install -r requirements.txt
(install required python packages)./development-manage.py migrate
(migrate, for staging or production./development-manage.py createsuperuser
(create an admin account) specify the required manage.py file instead)./development-manage.py setup
(sets up the project, most directory structure for now)./development-manage.py images
(optional - download all images for the catalog. For ~9000 images, expect about two hours on a high speed connection.)./development-manage.py runserver 8000
(running the server)
The project is required to have customised machine specific settings.
Those settings need to included or overridden in the local settings file.
Create one local.py
in the settings module next to the other settings
files (base.py
, development.py
, production.py
etc.)
The following settings needs to be present in the local.py
settings file.
-
The base and media directories:
import os BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) MEDIA_URL = '/media/' # The media URL MEDIA_ROOT = 'media/' # The location on disk, set this to the location of the shared mounted filesystem
-
The secret key used to authenticate the workflow with the UI API (can be generated with e.g. https://www.miniwebtool.com/django-secret-key-generator/)
SECRET_KEY = 'some really long string with $YMb0l$'
-
The admins of the site who will receive error emails.
ADMINS = [ ('Your Name', 'youremail@dd.ress'), ] MANAGERS = ADMINS
-
The address from where the server emails will be sent.
SERVER_EMAIL = 'serveremail@dd.ress'
-
The address from where the notification emails will be sent.
EMAIL_FROM = 'mail@dd.ress'
-
Other email settings can also be provided.
EMAIL_HOST = 'gpo.dd.res' EMAIL_PORT = 25 EMAIL_USE_TLS = True EMAIL_USE_SSL = False
-
Database settings. For example, a simple MySQL database can be configured using
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'zooniverse_dev', 'USER': 'django', 'PASSWORD': 'test-password#1', 'HOST': 'db', 'PORT': 3306, } }
-
Set the login redirect url (optional). Set the page you want the user to see after login. If not set, it redirects to
/accounts/profile/
LOGIN_REDIRECT_URL = '/'
(Optional) Force the https protocol even if the request is not secure in links. Specially helpful in case server is hosted on a different machine and apache redirect is sent there.
HTTP_PROTOCOL = 'https'
In case you choose to run this code as Docker containers, this section provides basic information about how to proceed.
Here are a few steps [assuming you have set your local.py file (see previous section)]:
-
Install docker and docker-compose, which can downloaded from: https://docs.docker.com/compose/install/#install-compose
-
Once docker is launched, open a terminal and navigate to the project's repository.
At the root of the project's repository are included the files
Dockerfile
anddocker-compose.yml
. For all the following steps have to be executed from that repository (or otherwise add the path to the files). -
From there, type:
docker-compose up -d --build
This will download Python, MySQL, and install most python packages. Once installed, the container will be launched. It should also run most of the
python development-manage.py <command>
commands for you. -
Now that this has finished, type:
docker ps
This will display the different docker processes currently running (e.g.
dg_zooniverse
andmysql_zooniverse
). -
As we want to create a superuser with
development-manage.py
, connect to dg_zooniverse with:docker exec -ti dg_zooniverse bash
.This will open a new shell where you see the virtual webserver. Here, we can simply type the usual commands that are on the project wiki. So:
python development-manage.py createsuperuser
. This will prompt you to add a username, email and password.As a sanity check, check that everything is correctly set by typing the following (it should have been executed with
docker-compose up -d --build
):pip3 install GPy
cp -r extern/acton /usr/local/lib/python3.6/site-packages/
python3 development-manage.py migrate
python3 development-manage.py setup
-
To quit the virtual server, simply type
exit
. The server will still be running.
Open a browser, and go to http://0.0.0.0:8000
.
If nothing shows up, try docker-compose restart
.
To stop all of these processes, type docker-compose stop
. You can restart it with docker-compose up -d
(-d
stands for “detached”, and can be omitted if you wanna see the server’s output).
Note that the database information present in the docker-compose.yml
file should match the database information in local.py
.
The project is licensed under the MIT License. For more information, please refer to the LICENSE document.
- Shibli Saleheen (as part of ADACS)
- Dany Vohl (as part of ADACS)