Product | IATI Dashboard |
---|---|
Description | A Django web application that provides key numbers, statistics and graphs about the data on the IATI registry. This repository is currently a development version where the IATI Dashboard/Publishing Statistics and Code for IATI Analytics are being merged. |
Website | Development only; see IATI Dashboard, and Code for IATI Analytics for live versions. |
Related | Repositories for the live version of the IATI Dashboard, live version of the IATI Publishing Stats, and Code for IATI Analytics. Data is generated from Code for IATI Stats. |
Documentation | Rest of README.md |
Technical Issues | See https://github.com/IATI/IATI-Dashboard/issues |
Support | https://iatistandard.org/en/guidance/get-support/ |
- Python 3.12
- Unix-based setup (e.g., Linux, MacOS X) with
bash
,wget
andcurl
installed. - Development files for libfreetype, libpng, libxml and libxslt e.g.
libfreetype6-dev libpng-dev libxml2-dev libxslt-dev
.
The IATI Dashboard is mostly written in Python but also has some helper Bash scripts to collect the data that the dashboard uses. Top-level steps required to run the Dashboard are:
- Setup Python environment and install dependencies.
- Fetch the data.
- Build the static graphs and other data that will be served via the Dashboard.
- Run the web server.
Paths to different directories are set in ./dashboard/config.py
.
Assuming that this repository has been cloned and you are in the root directory of the repository.
# Setup and activate a virtual environment (recommended) - here we use virtualenv
virtualenv ve
source ve/bin/activate
Now install the dependencies.
pip install -r requirements.txt
Bash scripts are used to fetch the data that the Dashboard will present. They will store data in ./data
and ./stats-calculated
.
# Fetch the necessary calculated stats
./get_stats.sh
# Fetch some extra data from github and github gists and other sources on the internet
./fetch_data.sh
mkdir out
python -m iati_dashboard.make_plots
python -m iati_dashboard.make_csv
python -m iati_dashboard.speakers_kit
DEBUG=True python manage.py runserver
The Dashboard will now be accessible from localhost:8000/
.
There are some unit tests written using pytest
and site testing using Django's own testing framework.
Once the development dependencies have been installed the unit tests can be run with:
pytest
The Django site tests can be run from the dashboard/
directory with:
python manage.py test -v 2
The IATI Dashboard requires a stats-calculated
directory, which can be downloaded using the get_stats.sh
shell script as described above. This can also be calculated using Code for IATI Stats where stats-calculated
corresponds to the gitout
directory generated by git.sh
in IATI-Stats.
Often you only want to regenerate the current stats, use get_stats.sh
to download the pre-calculated historical stats and just replace the stats-calculated/current directory
with the out
directory produced by running the loop, aggregate and invert commands individually, then regenerate graphs and CSV files as per the above.
If a change requires new dependencies then please add to requirements.in
or requirements_dev.in
as appropriate and recompile:
pip-compile requirements_dev.in
pip-compile requirements.in
Code linting is carried out using Flake8 and setup.cfg
has the configuration.
Copyright (C) 2013-2015 Ben Webb <[email protected]>
Copyright (C) 2013-2014 David Carpenter <[email protected]>
Copyright (C) 2021 Andy Lulham <[email protected]>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.