Skip to content

HowTheyVote.eu allows anyone to easily find out how Members of the European Parliament vote in plenary.

License

Notifications You must be signed in to change notification settings

HowTheyVote/howtheyvote

Repository files navigation

HowTheyVote.eu

HowTheyVote.eu makes vote results of the European Parliament transparent and accessible – for citizens, journalists, and activists.

The European Union is one of the largest democracies in the world. The European Parliament, with its 720 members from the EU’s 27 member states, represents just over 440 million Europeans. Although the Parliament publishes information such as agendas, minutes, and vote results on its website, it can be quite difficult to find out what MEPs voted on or how a particular vote turned out. HowTheyVote.eu compiles voting data from various official sources and allows anyone to search for votes and view the results.

Read more about HowTheyVote.eu →

Development environment

In order to set up a development environment on your computer please make sure you have Docker and Docker Compose installed on your computer.

Before you run HowTheyVote.eu locally for the first time, you will need to install dependencies for the frontend and backend:

docker compose run --rm frontend npm install
docker compose run --rm backend poetry install

Create an .env file according to .env.template.

Upgrade the system to run database migration and configure the search index:

docker compose run --rm backend htv system upgrade

Finally, you can start all required containers:

docker compose up -d

You can now access the application at https://localhost. Note that we use self-signed TLS certificates during development. Your browser will most likely display a certificate warning when you open the application for the first time.

At this point, there isn’t yet any data in your local database. You can use the CLI to run data pipelines.

CLI

The htv CLI is installed in the backend container and provides a few commands that can be helpful during development. In order to run CLI commands make sure to first create a shell in the backend container:

docker compose exec backend bash

While we use a background worker to run data pipelines on a regular schedule in production, you can also run them manually using the CLI:

htv pipeline members --term=10
htv pipeline sessions --term=10
htv pipeline rcv-list --term=10 --date=2024-07-17
htv pipeline press --date=2024-07-17

In order to run all data pipelines for an entire term, run the following command. Please note that this command may take multiple hours to complete.

htv pipeline all --term=10

Parts of this work were sponsored by the Federal Ministry of Education and Research in the 9th round of the Prototype Fund in 2021 (Reference: 01IS21818). Throughout 2025, this project is supported by the MIZ Babelsberg.

Logo of the Federal Ministry of Education and Research of Germany, the Prototype Fund and the MIZ Babelsberg.