项目作者: republique-et-canton-de-geneve

项目描述 :
Electronic vote system, version 1.
高级语言: Java
项目地址: git://github.com/republique-et-canton-de-geneve/chvote-1-0.git
创建时间: 2016-11-25T08:39:52Z
项目社区:https://github.com/republique-et-canton-de-geneve/chvote-1-0

开源协议:GNU Affero General Public License v3.0

下载


CHVote Build Status

CHVote aims to be an opensource, publicly owned evoting system. It is the result of the collaboration
between the Geneva State Chancellery and the Geneva IT Department.

CHVote is currently used by 4 cantons in Switzerland: Basel-City, Bern, Geneva and Luzern, either for
votations or elections.

Table of contents

Released components

The following components are released as opensource software:

  • The offline administration application
  • Various utility libraries needed by this application

The goals of the offline administration application are to:

  • generate the keys responsible for encrypting and decrypting the stored ballots, using passphrases from the
    electoral board;
  • test the generated keys and the passphrases;
  • decrypt the ballots.

The security objective of having an offline application is to ensure that the private key able to decrypt the ballots
is never known to any system other than the offline application and its offline laptop.

The offline administration application is a key component of the evoting system in that it is the only one responsible
for creating and using the private decryption key.

System overview

Please read the system overview documentation to learn how the published
components contribute to the evoting system. You’ll get an overview on the following themes:

  • the election process;
  • the system architecture including focuses on the ballot box cryptography and the use of the offline administration
    application;
  • the security concept.

Compiling and running

Preconditions

The following software must be installed to compile and run the application:

We do not provide support for the use of OpenJDK/OpenJFX.

Compiling

Compile and install the 3 modules in this sequence:

  1. cd $PROJECT_ROOT/base-pom
  2. mvn clean install
  3. cd $PROJECT_ROOT/commons-base
  4. mvn clean install
  5. cd $PROJECT_ROOT/admin-offline
  6. mvn clean install

Some JDK distributions do not come with the Monocle classes used by the headless GUI tests. If you’re running into those cases
(java.lang.AbstractMethodError: com.sun.glass.ui.monocle.NativePlatform.createInputDeviceRegistry appearing in the test logs),
use the following command to skip the GUI tests:

  1. cd $PROJECT_ROOT/admin-offline
  2. mvn -P skipJavaFXTests clean install

Running

Run the application with maven:

  1. cd $PROJECT_ROOT/admin-offline
  2. mvn exec:java -Dexec.mainClass="ch.ge.ve.offlineadmin.OfflineAdminApp"

Contributing

CHVote is opensourced with the main purpose of transparency to build confidence in the system.

Contributions are also welcomed, either using pull requests or by submitting issues in github. The CHVote community
manager will take care of those inputs, lead exchanges around them, and actions could take place according to their
relevance, their criticality, and the CHVote development roadmap.

Pull request policies

The master branch is dedicated to mirror the state of the production code.

  • Please use the development branch for pull requests
    modifying the source code.
  • You can however use the master branch for pull requests concerning the documentation only.

Security

In case of vulnerability discovery, please use the following email address for coordinated disclosure: security-chvote@etat.ge.ch.

Licence

CHVote components are released under AGPL 3.0.

Future

The second generation of CHVote has been under active development in 2017 and 2018. The project has since been discontinued and will not be put into production. It aimed to provide end-to-end encryption with individual
and universal verifiabilities. Its source code is published here: https://chvote2.gitlab.io.