Skip to content

Bernie-2016/vincent

Repository files navigation

Vincent

Vincent is a system for reporting, assigning, and tracking voter protection incidents.

Goals

  1. Streamline data entry for attorneys.
  2. Help lead attorneys triage & admins effectively triage the "hottest" issues amongst their thinly spread field attorney resources.
  3. Location reporting, especially – make that as dead simple as possible.

Features

  1. Geolocation. Click "Find polling locations near me" and it gives the attorneys a list of places to choose from. Boom.
  2. A highly customized Django admin to slice and dice incidents that need tracking.
  3. GeoDjango niceness, for filtering (and visualizing) incidents, with help from Leaflet.
  4. Stork Jobs to porting data around. More on that in a minute.

Requirements

Installation

  1. git clone [email protected]/Bernie-2016/vincent.git
  2. cd vincent
  3. mkvirtualenv vincent
  4. pip install -r requirements.txt
  5. Rename .env.sample to .env and update SECRET_KEY and DATABASE_URL (and, for email invite support, MAILGUN_ACCESS_KEY and MAILGUN_SERVER_NAME)
  6. ./manage.py migrate
  7. Seed some data into your local database
  8. ./manage.py runserver

But how do I even?

It really only needs three things in an ongoing basis:

  1. Clear out issues. Marking them Closed or even Deleting them would probably do the trick.
  2. Loading attorney users. Create a CSV file with these fields: 'First Name', 'Last Name', 'Email', 'Phone', 'Group', and see ./manage.py load_users for doing that; it will email out invites.
  3. Populating polling locations (with precinct rankings) via Stork job.

That last one's going to require some elaboration — somewhere in the bowels of Vertica, there's:

  1. A Stork job to pull all the polling place locations within a given set of states (specified by abbreviation). Find that job and sub in the states you need. You'll want to run this close to / the night before Election Day.
  2. Run ANOTHER Stork job, on that data, to use SmartTarget's geocoding service to produce lat / lng pairs on each of those points.
  3. Run a third Stork job, to pipe ALL that composite data, over to Vincent's Postgres Database.

The jobs all exist, almost surely owned by me (Jon Culver). It's a bit to wrap your head around but most of the pieces are in place. Run them and wait (the state of CA, for example, might take a few hours to geocode entirely) and then you're gold!

Screenshots

Login Page Login Page

Assigned Incidents Incidents

Incident Report Incident Report

Vincent Admin Admin

Releases

No releases published

Packages

No packages published