This project is deprecated and no longer maintained. We are consolidating efforts into a static generated website approach using disclosure-backend-static and odca-jekyll.
This is the back-end Django application for scraping ballot measure funding data (from NetFile and CalAccess), pushing it to our database, and exposing the data to our front-end apps via a RESTful API.
Helpful links:
See below for server setup.
Mock-ups for data tables that this app intends to support are here: https://github.com/caciviclab/caciviclab.github.io/wiki/Mock-ups
If you've worked with Django and python before, these steps should be familiar to you. We're going to create an environment with Python 2.7.9 for the project
Clone disclosure-backend
(or your fork of it) to your own local copy.
Install python
or anaconda
or conda
(If using OSX (Mac) python is
already installed, if using Linux, install anaconda, if using Windows, you
can choose between conda and python but we recommend python)
Install pip
(if using Anaconda, pip is already installed.)
sudo easy_install pip
Create an environment for this project:
For non-Anaconda Python distribution
sudo pip install virtualenv
virtualenv env
source env/bin/activate
For Anaconda (we'll make an environment called ODB with Python 2.7.9 in it)
conda create --name ODB python=2.7.9
source activate ODB
You will have to activate this environment (or virtualenv) every time you want to start working. You activate using:
source env/bin/activate
Or
source activate ODB
Install mysql and other system dependencies
OSX:
brew install pkg-config
pkg-config --cflags-only-I libcgraph
brew install mysql
brew install libssl
brew install graphviz
brew install libssl
does not work don't worry about it.Install project requirements with:
pip install -r requirements.txt
pip install -r requirements_dev.txt
fatal error: 'graphviz/cgraph.h' file not found
?
Runcd /usr/local/Cellar/graphviz/2.38.0/include/graphviz/
mkdir graphviz
cp cgraph.h graphviz/
Then try
pip install -r requirements_dev.txt
Create the database
mysql -u root
mysql> create database opendisclosure;
mysql> create database calaccess_raw;
mysql> \q
Run the server setup script
python manage.py setuptestserver
This will run database migrations, add a superuser (username: admin
, password: admin
),
and other setup steps.
OSX: If you get the following error django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module: dlopen(_mysql.so, 2): Library not loaded: libssl.1.0.0.dylib
Then, you need to add openssl to your DYLD_LIBRARY_PATH
:
/usr/local/Cellar/openssl/
, and locate your directory (e.g. 1.0.2d_1)~/.bash_profile
:
export DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH:/usr/local/Cellar/openssl/1.0.2d_1/lib
python manage.py test
It should load and clean some files in a few seconds.
Note: if this fails with an SSL error and you are using conda/miniconda, use virtualenv instead. See this link for details about the conda issue.
A basic data check to make sure things are working:
python manage.py downloadcalaccessrawdata --use-test-data
python manage.py downloadzipcodedata
Netfile contains campaign finance data for a number of jurisdictions. Not all jurisdictions will have data.
# Download netfile data and load into calaccess_raw.NETFILE_CAL201_TRANSACTION
python manage.py downloadnetfilerawdata
# Process NETFILE_CAL201_TRANSACTION into opendisclosure
python manage.py xformnetfilerawdata
To run for the purposes of development, accessing Django's admin interface:
python manage.py runserver
Then go to http://127.0.0.1:8000/admin to log in and see data.
For deployment to the official website:
ssh opencal.opendisclosure.io /usr/local/bin/deploy-backend