This WeVoteServer repository contains a Python/Django-powered API endpoints server. We take in ballot data from Google Civic API, Ballotpedia, Vote Smart, MapLight, TheUnitedStates.io and the Voting Information Project. We then serve it up to voters, and let voters Support/Oppose and Like ballot items. We are also building tools to capture and share voter guide data.
You can see our current alpha version for recent national and some reigonal elections here: https://WeVote.US/
To get started as a We Vote developer, sign the Contributor License Agreement.
We have two sets of install instuctions, the first is a simplified version specifically for the Mac, and the second is a more detailed set with more options for Linux and AWS
-
Use these Simplified Instructions for Mac leveraging the free (and powerful) PyCharm IDE and debugger (recommended!)
-
Or use these more detailed Installation instructions that also cover installation on Linux and in AWS
The website front end application is powered by the We Vote WebApp
We distribute the We Vote WebApp in an Apache Cordova wrapper, with some native features, to provide iOS and Android apps.
See the iOS We Vote 2018 Ballot, @WeVote in the iTunes app store for iPhones and iPads.
See the Android We Vote 2018 Ballot, @WeVote in the Google Play store for most Android phone and tablet devices.
We also have a ReactNative for iOS and Android that is currently on hold.
Read about working with WeVoteServer on a daily basis
If you need to test donations and have not updated your openssl and pyopenssl during install and setup, you will need to update your local.
See Instructions for Scheduled Tasks
How to run the WeVoteServer tests
How to run the WeVoteServer Locust Load Tests
We meet weekly on Google hangouts, and on a team Slack. Please contact Dale.McGrew@WeVote.US for more information.